内容简介:在日常使用github中,除了利用git进行项目版本控制之外,最多的用处就是游览各式的项目,在看到一些有趣或者有用的项目之后,我们通常就会顺手star,目的是日后再看。但是当我们star了许多项目之后,回过头想找一个的项目就会发现,很难在短时间内找到它,官方也并没有提供很好的管理我们的star项目的功能,因此在市面上也出现了一些对star进行管理的工具,比如说astralapp,Star Order等等,其实github的接口api都是开放的,我们完全可以自己构建一个属于自己的项目管理工具。公司的前端技术
在日常使用github中,除了利用git进行项目版本控制之外,最多的用处就是游览各式的项目,在看到一些有趣或者有用的项目之后,我们通常就会顺手star,目的是日后再看。但是当我们star了许多项目之后,回过头想找一个的项目就会发现,很难在短时间内找到它,官方也并没有提供很好的管理我们的star项目的功能,因此在市面上也出现了一些对star进行管理的工具,比如说astralapp,Star Order等等,其实github的接口api都是开放的,我们完全可以自己构建一个属于自己的项目管理工具。公司的前端技术栈是React,而笔者之前使用的是Vue,因此正好想利用github的open api 自己构建个react的github star管理项目来加深react的使用。而大体功能我们就模仿astralapp。
github open api
官方文档有v3和v4,2个版本,v3是Restful,v4是GraphQL,在这里我们使用的是v3版
v3
使用的是restful 协议
服务器地址
https://api.github.com 复制代码
在无token情况下使用github的api,每分钟限制是60次请求,考虑到想完整的使用github的api,因此选择构建一个 web application ,授权OAuth应用程序的流程可以参照 官方文档 。在这里,就简单的说一下这个流程。
授权OAuth2.0 的流程
github OAuth的授权模式为授权码模式,对OAuth不了解的同学可以具体看阮一峰老师的理解OAuth 2.0
要做的流程主要分为3步
- 获取code
- 通过code获取token
- 在请求时携带token
获取code
首先需要跳转到这个地址
https://github.com/login/oauth/authorize 复制代码
需要有以下参数
参数名 | 类型 | 描述 |
---|---|---|
client_id | string | 必选 client_id是在注册github application后可以看到 |
redirect_uri | string | 可选 授权成功后跳转的地址,这里的这个跳转地址也可以在后台进行设置 |
scope | string | 可选 权限范围,具体的权限可以参照,具体传值格式以及需要哪些范围可以参照 官方文档 |
allow_signup | string | 可选 是否允许为注册的用户注册,默认为true |
跳转至目标地址后,会有个授权界面,当用户点击授权之后会重新跳转到我们自己设定的 redirect_uri
并携带一个code,就像这样
<redirect_url>?code=1928596028123 复制代码
通过code获取token
在获取code之后,请求用于获取token
POST https://github.com/login/oauth/access_token 复制代码
参数名 | 类型 | 描述 |
---|---|---|
client_id | string | 必填 client_id是在注册github application后可以看到 必填 |
client_secret | string | 必填 该参数是在同 client_id 一样,也是在注册 application 后可以看到 |
code | string | 必填 通过第一步获取 |
redirect_uri | string | 可选 |
state | string | 可选 随机数 |
token的默认返回格式为字符串
access_token=e72e16c7e42f292c6912e7710c838347ae178b4a&token_type=bearer 复制代码
可以通过更改头部接受格式进行返回格式变更
Accept: application/json {"access_token":"e72e16c7e42f292c6912e7710c838347ae178b4a", "scope":"repo,gist", "token_type":"bearer"} Accept: application/xml <OAuth> <token_type>bearer</token_type> <scope>repo,gist</scope> <access_token>e72e16c7e42f292c6912e7710c838347ae178b4a</access_token> </OAuth> 复制代码
在请求时携带token
携带token有2种方式 一种是永远跟在url的后面作为params
GET https://api.github.com/user?access_token=... 复制代码
另外一种是放在请求头中
Authorization: token 获取到的token 复制代码
接口请求
在项目里运用到的github 接口 目前有三个
- 用户信息接口
- 当前用户star的项目
- 获取项目Readme接口
需要注意的是这些接口由于服务端实现了CORS,因此是不存在跨域问题,但是,考虑到本身这个项目的功能情况,之后我们会自己建立服务端进行请求。
用户信息接口
GET https://api.github.com/user 复制代码
GET https://api.github.com/user/starred 复制代码
可选的请求参数
参数名 | 类型 | 描述 |
---|---|---|
page | string | |
sort | string | 排序条件 有2种 created updated ,默认为 created |
direction | string | 升序还是倒序 asc desc ,默认为``desc |
获取仓库Readme接口
GET https://api.github.com/repos/:username/:repo/readme 复制代码
针对一些文件接口,github提供了头部类型的选择,可以返回不同的文件类型,比如raw等,具体可以参考官方文档中的 Custom media types
在这里我们需要的是html格式,因此 我们在头部当中设置
"Accept": "application/vnd.github.v3.html" 复制代码
这样ReadMe返回的是html代码,我们根据html代码直接显示即可。
目录结构
├── config // webpack相关文件 ├── public // 公用文件 ├── scripts // 脚本文件 build,start,test文件都在里面 ├── src ├── assets // 自己放置的资源文件 ├── components // 公用组件 ├── pages // 页面文件 ├── utils // 公用方法文 App.css App.scss App.jsx index.css index.js logo.svg reset.css // 重置样式 variable.css variable.scss // 公用变量文件 ├── package.json ├── .editorconfig // 编辑器配置 ├── .gitignore // git 忽略文件 复制代码
构建
create-react-app
构建React项目首先第一个想到的是用脚手架工具,Vue当中有Vue-cli,自带webpack,vue-router,vuex,而React对应的是 create-react-app
当我们初始化完成项目之后,我们会发现webpack的配置文件找不到,我们需要运行以下命令将wepack配置显示出来
npm run eject 复制代码
scss
这个方法参照的是 create-react-app
中的说明 adding-a-css-preprocessor-sass-less-etc
npm install --save node-sass-chokidar 复制代码
还需要装 webpack watch
"scripts": { + "build-css": "node-sass-chokidar src/ -o src/", + "watch-css": "npm run build-css && node-sass-chokidar src/ -o src/ --watch --recursive", "start": "react-scripts start", "build": "react-scripts build", "test": "react-scripts test --env=jsdom", 复制代码
npm install --save npm-run-all 复制代码
"scripts": { "build-css": "node-sass-chokidar src/ -o src/", "watch-css": "npm run build-css && node-sass-chokidar src/ -o src/ --watch --recursive", - "start": "react-scripts start", - "build": "react-scripts build", + "start-js": "react-scripts start", + "start": "npm-run-all -p watch-css start-js", + "build-js": "react-scripts build", + "build": "npm-run-all build-css build-js", "test": "react-scripts test --env=jsdom", "eject": "react-scripts eject" } 复制代码
安装好这些包之后,新建一个scss文件会自动生成css文件,我们在引用时直接引用css文件即可。
另外一种方法是参照medium的一篇文章 CSS Modules & Sass in Create React App 。
npm i sass-loader node-sass --save or yarn add sass-loader node-sass 复制代码
随后更改 webpack.config.dev.js
文件的配置
loaders
用
use
代替,随后在file-loader增加scss文件格式的匹配
跨域问题
跨域问题可以使用webpack自带的proxy进行配置,或者通过ngix进行代理
如果是webpack配置需要在package.json当中进行配置
"proxy": { "/user": { "target": "https://api.github.com", "changeOrigin": true }, "/user/star": { "target": "https://api.github.com", "changeOrigin": true }, "/login": { "target": "https://github.com", "changeOrigin": true } } 复制代码
svg
目前使用了 svg-react-loader
/* eslint-disable */ // 主要是这里 eslint会报错 import Refresh from '-!svg-react-loader!../../assets/img/refresh.svg'; /* eslint-enable */ class StarFilter extends Component { constructor(props) { super(props); require.resolve('svg-react-loader'); this.state = { }; } componentDidMount() { } render() { return ( <div className="star-filter"> <div className="title-container"> <h3 class="title-gray-dark">STARS</h3> <!--这样就可以使用了--> <Refresh className="icon-refresh text-grey" /> </div> </div> ); } } export default StarFilter; 复制代码
颜色
改变颜色要使用 fill
属性
.icon-refresh { width: 20px; height: 20px; fill: #606f7b; } 复制代码
注意
fill
引用本地图片
import NoSelectedImg from '../../assets/img/not-selected.svg'; class ResInfo extends Component { // ..此处省略 render() { <img alt="no-selected" src={NoSelectedImg} className="img-no-selected" /> } } export default ResInfo; 复制代码
第二种方法是用 require
<img src={require('../../assets/img/status-spinner.svg')} alt="fetch" width="16" height="16"/> 复制代码
需要注意的是如果是要在 img
标签中使用svg图片,还需要在webpack当中进行配置,在 webpack.config.dev.js
和 webpack.config.prod.js
当中大致在133行左右的 urlLoader
增加svg文件的匹配
{ test: [/\.bmp$/, /\.gif$/, /\.jpe?g$/, /\.png$/, /\.svg$/], loader: require.resolve('url-loader'), options: { limit: 10000, name: 'static/media/[name].[hash:8].[ext]', } 复制代码
路由
使用 react-router-dom
进行路由的管理,和 Vue-router
一样,需要对要用到的路由级别组件进行注册。直接将组件写在 router
内部即可。
render() { return ( <div className="App"> <BrowserRouter basename="/"> <div> <Route exact path="/" component={Auth} /> <Route path="/auth" component={Auth} /> <Route path="/star" component={Star} /> </div> </BrowserRouter> </div> ) } 复制代码
Router
中有 BrowserRouter
, HashRouter
等,而这2种类似于 Vue-router
中的 history
和 hash
模式,需要注意的是,在我们这个项目当中必须使用 BrowserRouter
,如果使用 HashRouter
在github 授权重定向回我们页面时会出现问题。会出现code不在尾部的问题。
import { Redirect } from 'react-router-dom' class Auth extends Component { //省略... render() { // 如果isTokenError为true直接跳转至首页 if (this.state.isTokenError) { return ( <Redirect to="/"/> ) } // 如果hasCode有值则跳转至star if (this.state.hasCode) { return ( <Redirect to="/star" /> ) } return ( <div className="Auth"> <Button className="btn-auth" onClick={this.onClickAuth}> 点击授权 </Button> </div> ) } } export default Auth 复制代码
同时它也支持api的跳转,当组件放置在 router
中,组件props内置会有一个 histroy
属性,即 this.props.history
,使用它就可以实现 push
, replace
等跳转了功能了。
/** * 返回首页 */ go2home() { this.props.history.replace('/auth'); } /** * 前往star界面 */ go2star() { this.props.history.push('/star'); } 复制代码
总结
我们大致了解了项目的概况,在开发项目的过程当中,官方文档是十分重要的,包括githubApi的使用,SCSS的使用,跨域问题等等,都能从官方文档当中得到解答。同时github提供的api也是十分丰富的,基本囊括了所有github的基础功能,在上述文章当中只是展示了它极少的功能,更多的功能大家可以自己来发掘。在接下来的文章当中,会为大家带来服务端开发篇,使用node进行服务端,数据库的一些操作。项目地址可以 点我 ,项目还在初期开发中,就不要来star了=.=。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。