作者简可11

https://juejin.im/post/5c4c738ce51d4525211c129b

0.前言

好吧,也许大部分人进来都会想,为什么人会反复做轮子,GitHub的第三方客户端早就把街给毁了。确实一开始我也是这么觉得的,问自己这样的项目再做一次真的有意义吗?反复思考,以下原因也决定了我愿意做一个让自己满意的第三方GitHub客户端。

对于一直关注GitHub Trending列表的作者来说,迫切需要一种更容易的方式,随时随地跟踪GitHub的最新技术动向;

现有的一些GitHub小程序客户端值和功能不能满足作者的要求;

听说没人要iOS开发,那为什么不掌握一门新的开发技能呢?

其实没有那么多原因。如果你想做,就去做。幸福是最重要的。

1.Gitter

GitHub:

https://github.com/huangjianke/Gitter

可能是目前价值最高的GitHub小程序客户端,欢迎之星

数据源:

GitHub API v3

https://developer.github.com/v3/

目前的功能是:

查看实时趋势

显示用户列表

搜索仓库和用户

仓库:详细信息显示、README.md显示、星形/非星形、分叉、贡献者显示,以及查看仓库文件的内容

开发者:关注/不关注,展示用户关注/关注

问题:查看问题列表,添加问题,并添加问题注释

共享仓库,开发者

...

Gitter的初衷并不是把网页上的所有功能都复制到小程序上,因为那样的体验不会很友好。比如作者本人不想看手机上的代码,那会是一件很痛苦的事情。

让用户在保证用户体验的前提下,以更简单的方式得到自己想要的东西,这很有意思。

2.探索文章

技术选择

第一次觉得自己在广阔的前端世界里是那么渺小。

当我决定做这个项目的时候,我开始了不间断的技术选择,但是我面前的选择太多了,我不得不觉得前端世界真的很棒。

原生开发:刚开始基本放弃,开发体验很不友好;

WePY:

https://tencent.github.io/wepy/

以前已经用这个框架开发了一个小程序,

诗人和诗人,

https://github.com/huangjianke/weapp-poem

不得不说坑这么多,用过的人都知道;

mpvue:

http://mpvue.com/

用Vue开发小程序,个人感觉文档不是很全,最近维护比较少,可能比较稳定?

芋头:

https://taro.aotu.io/

利用React开发小程序,芋头团队的小伙伴们真的是勤于维护,耐心解答大家的疑问。文档比较齐全,开发经验也很棒。您也可以一键生成多端运行代码。

逛了一圈,经过一段时间的尝试和踩坑,结合我目前的能力,最终确定了吉特的技术选型:

Taro+Taro UI+Redux+云开发节点. js

https://taro-ui.aotu.io/#/docs/introduction

页面设计

其实作为一个编码器,我一直想找一个姐姐UI设计师做老婆。多般配啊。现在想想,代码不是生活的全部,我现在也一样开心。

让我们回到正题。没有设计师的老婆怎么办?毕竟我要的是一个价值很高的GitHub小程序。

嗯,不急不忙,默默的拿出我沉默了很久的Photoshop和Sketch。我不敢说我的设计能力如何。Gitter的设计至少能让我感到开心。如果有设计爱好者想改进Gitter的设计,欢迎,欢迎!

3.开篇文章

说话便宜。给我看看代码。

作为一篇技术文章,怎么能少拿代码?

这里主要写几个踏点。作为一个前端小白,相信所有的读者都是作者的前辈,希望大家多多指教!

趋势

进入开发阶段没多久,就遇到了第一个坑。GitHub不提供趋势列表的API!!!

我没有过多考虑GitHub为什么不提供这个API,只是考虑如何尽快填补这个漏洞。首先尝试使用scratch

写一个爬虫定期抓取并存储网页上的趋势列表信息供小程序使用,但最后还是放弃了这个做法,因为作者没有服务器和注册域名,小程序的云开发只支持Node.js的部署

开源依旧强大,终于找到了github-trending-api。

https://github.com/huchenme/github-trending-api

稍加修改,成功部署到小程序云开发后台。在此,我要感谢原作者的努力。

攀登趋势知识库

async functionfetchrepositories {

const URL = ` $ { GITHUB _ URL }/trending/$ { language }?自= $ {自} `;

const data = await fetch;

const $ = cheerio . load);

返回

。get

//ESL int-disable-下一行复杂性

。map;

consttitle = $回购

。查找

。文本

。trim;

constrelativeUrl = $ repo

。查找

。查找

。attr;

constcurrentPeriodStarsString =

$回购

。find

。文本

。trim || /*伊斯坦布尔忽略下一个*/' ';

constbuiltBy = $回购

。查找')

。父项

。查找

。map= > 1 . 0 . 0。{

constaltString = $

.children 。儿童

。attr;

constavatarUrl = $

.children 。儿童

。attr;

返回{

用户名:altString

?altString.slice

:/*伊斯坦布尔忽略下一个*/null,

href:` $ { GITHUB _ URL } $ { user . attribs . href } `,

头像:removeDefaultAvatarSize,

};

})

。get;

constcolorNode = $ repo.find;

常量颜色=颜色节点。长度

?colorNode.css

:null

constlAnNode = $ repo . find;

constlang = langNode.length

?langNode.text。修剪

:/*伊斯坦布尔忽略下一个*/null;

returnomitNil,

名称:title.split,

URL:` $ { GITHUB _ URL } $ { Relatitudeurl } `,

deion:

$回购

。find

。文本

。trim || /*伊斯坦布尔忽略下一个*/' ',

语言:朗,

语言颜色:语言颜色,

star:ParSeint

。文本

。替换|| /*伊斯坦布尔忽略下一个*/0,

10

),

forks: parseInt

。文本

。替换|| /*伊斯坦布尔忽略下一个*/0,

10

),

currentPeriodStars: parseInt。替换||

/*伊斯坦布尔忽略下一个*/0,

10

),

建筑,

});

})

);

}

抓取趋势开发者

asynccfunctionfetchdeveloper {

constdata = awaitfetch;

const $ = cheerio . load);

返回$

。get

。地图;

constrarelativeURl = $ dev . find。attr;

constname = getMatchString

。文本

。trim,

/^)$/i

);

$dev.find。移除;

constusername = $dev

。find

。文本

。trim;

const$repo = $dev.find;

returnomitNil.attr), avatar:removeDefaultAvatarSize。attr,

回购:{

名称:$回购

。find

。文本

。trim,

deion:

$回购

。find

。文本

。trim || /*伊斯坦布尔忽略下一个*/' ',

URL:` $ { GITHUB _ URL } $ { $ repo . attr} `,

},

});

});

}

趋势列表云功能

//云函数入口函数

exports.main = async =>。{

const{ type,language,after } =事件

letres = null

letdate = newDate

if{

constcacheKey = ` repositories::$ { language || ' nolang ' }::$ {自| |

daily ' } `;

constcacheData = await db . collection。其中.orderBy。get

if-cache data . data)。cacheDate)& lt;1800* 1000)) {

RES = JSON . parse

} else{

RES = awaitfetchRepositories;

await db . collection。添加,

缓存键:缓存键,

内容:JSON.stringify

}

})

}

} else if{

constcacheKey = ` developer::$ { language | | ' nolang ' }::$ {自| | ' daily ' } `;

constcacheData = await db . collection。其中.orderBy。get

if-cache data . data)。cacheDate)& lt;1800* 1000)) {

RES = JSON . parse

} else{

RES = awaitfetchdeveloper;

await db . collection。添加,

缓存键:缓存键,

内容:JSON.stringify

}

})

}

}

返回{

数据:res

}

}

降价分析

嗯,这是个大坑。

在做技术研究的时候发现,对于小程序端的Markdown解析,主要有以下几种解决方案:

wxParse:

https://github.com/icindy/wxParse

作者最后一次提交是在两年前。经过自己的尝试,他确实发现不适合解析README.md之类的

wemark:

https://github.com/TooBug/wemark

一个非常不错的微信小程序Markdown渲染库,但是作者尝试后发现README.md的解析并不完善

towxml:

https://github.com/sbfkcel/towxml

目前发现是微信小程序最完善的Markdown渲染库,几乎可以完美分析显示README.md

在Markdown解析中,最终采用towxml,但是发现目前解析性能不是很好,解析一些比较大的数据超出了小程序能够承受的范围。还好有思想的作者提供了服务器的支持,感谢作者的努力!

降价分析云函数

constTowxml = require;

consttowxml = NewTowXMl;

//云函数入口函数

exports.main = async =>。{

const{ func,type,content } =事件

letres

if {

if {

RES = awaittowxml . Tojson;

} else{

RES = awaittowxml . Tojson;

}

}

返回{

数据:res

}

}

Markdown.js组件

导入Taro,{ Component }来自' @tarojs/taro '

从“道具类型”导入道具类型

从“@tarojs/components”导入{视图,文本}

从“taro-ui”导入{ AtActivityIndicator }

“进口”。/markdown.less '

'从导入到xml '../towxml/main

const render = new Towxml

导出DefaultClassMarkDownExtendsComponent {

static propTypes = {

MD:ProTypeS . string,

base:ProTypeS . string

}

静态defaultProps = {

md: null,

base: null

}

构造函数{

超级

this.state = {

数据:null,

失败:false

}

}

componentDidMount {

this.parseReadme

}

parseReadme {

const { md,base } = this.props

让那个=这个

wx.cloud.callFunction.然后 {

data= render.initData

}

that.setState

}).catch

that.setState

})

}

render {

const { data,fail } = this.state

if {

返回} & gt;

& ltText className= 'text'>。加载失败,再试一次?& lt/Text >

& lt/View >

)

}

返回 :

}

& lt/View >

)

}

}

Redux

事实上,作者在这个项目中并没有太多使用Redux。一开始,作者认为所有的接口请求都应该由Redux操作,但后来发现并不是所有的操作都必须使用Redux。最后,在这个项目中,只有在获得个人信息的情况下,才使用Redux。

//获取个人信息

export ConstGetUserInfo = CreateApiAction= & gt;api。get)

exportfunctioncreateApiAction= & gt;{}) {

返回=>。{},失败:=>。{} },

customActionType = actionType,

)= >;async= gt。{

尝试{

dispatch;

const data = await func;

dispatch;

回调。成功和。& ampcallback . success

returndata

} catch {

调度

回调. & amp& ampcallback.failed

}

}

}

getUserInfo {

if) {

userAction.getUserInfo。然后= >;{

Taro.hideLoading

Taro.stopPullDownRefresh

})

} else{

Taro.hideLoading

Taro.stopPullDownRefresh

}

}

const mapstatetorops == & gt;{

返回{

userInfo: state.user.userInfo

}

}

exportdefaultconnect

exportdefaultfunctionuser {

switch {

caseUSERINFO:

返回{

...州,

userInfo: action.payload.data

}

默认:

返回状态

}

}

目前作者还处于对Redux知之甚少的状态。嗯,还有很长的路要走。

4.结论

当第一版Gitter通过审核的时候,我很激动。就像我自己的孩子一样,看着他一点一点长大。我也很享受这样一个项目从无到有的过程。在这里,我要向帮助过我的人表示感谢。

当然,目前在功能和体验上可能存在一些不完善的地方,希望大家能提供一些有价值的意见。希望你在为吉特走向完美的路上!

最后,希望Gitter小程序能帮到你!

长的

根据

接近

填充

1.《gitter Gitter - 高颜值GitHub小程序客户端诞生记》援引自互联网,旨在传递更多网络信息知识,仅代表作者本人观点,与本网站无关,侵删请联系页脚下方联系方式。

2.《gitter Gitter - 高颜值GitHub小程序客户端诞生记》仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证。

3.文章转载时请保留本站内容来源地址,https://www.lu-xu.com/guoji/1670406.html