Gitter---高颜值GitHub小程序客户端诞生记,循序渐进

const currentPeriodStarsString =

$repo

.find(’.float-sm-right’)

.text()

.trim() || /* istanbul ignore next */ ‘’;

const builtBy = $repo

.find(‘span:contains(“Built by”)’)

.parent()

.find(’[data-hovercard-type=“user”]’)

.map((i, user) => {

const altString = $(user)

.children(‘img’)

.attr(‘alt’);

const avatarUrl = $(user)

.children(‘img’)

.attr(‘src’);

return {

username: altString

? altString.slice(1)

: /* istanbul ignore next */ null,

href: ${GITHUB_URL}${user.attribs.href},

avatar: removeDefaultAvatarSize(avatarUrl),

};

})

.get();

const colorNode = $repo.find(’.repo-language-color’);

const langColor = colorNode.length

? colorNode.css(‘background-color’)

: null;

const langNode = $repo.find(’[itemprop=programmingLanguage]’);

const lang = langNode.length

? langNode.text().trim()

: /* istanbul ignore next */ null;

return omitNil({

author: title.split(’ / ')[0],

name: title.split(’ / ')[1],

url: ${GITHUB_URL}${relativeUrl},

description:

$repo

.find(’.py-1 p’)

.text()

.trim() || /* istanbul ignore next */ ‘’,

language: lang,

languageColor: langColor,

stars: parseInt(

$repo

.find([href="${relativeUrl}/stargazers"])

.text()

.replace(’,’, ‘’) || /* istanbul ignore next */ 0,

10

),

forks: parseInt(

$repo

.find([href="${relativeUrl}/network"])

.text()

.replace(’,’, ‘’) || /* istanbul ignore next */ 0,

10

),

currentPeriodStars: parseInt(

currentPeriodStarsString.split(’ ‘)[0].replace(’,’, ‘’) ||

/* istanbul ignore next */ 0,

10

),

builtBy,

});

})

);

}

复制代码


*   爬取Trending Developers

async function fetchDevelopers({ language = ‘’, since = ‘daily’ } = {}) {

const data = await fetch(

${GITHUB_URL}/trending/developers/${language}?since=${since}

);

const $ = cheerio.load(await data.text());

return $(’.explore-content li’)

.get()

.map(dev => {

const $dev = $(dev);

const relativeUrl = $dev.find(’.f3 a’).attr(‘href’);

const name = getMatchString(

$dev

.find(’.f3 a span’)

.text()

.trim(),

/^((.+))$/i

);

$dev.find(’.f3 a span’).remove();

const username = $dev

.find(’.f3 a’)

.text()

.trim();

const $repo = $dev.find(’.repo-snipit’);

return omitNil({

username,

name,

url: ${GITHUB_URL}${relativeUrl},

avatar: removeDefaultAvatarSize($dev.find(‘img’).attr(‘src’)),

repo: {

name: $repo

.find(’.repo-snipit-name span.repo’)

.text()

.trim(),

description:

$repo

.find(’.repo-snipit-description’)

.text()

.trim() || /* istanbul ignore next */ ‘’,

url: ${GITHUB_URL}${$repo.attr('href')},

},

});

});

}

复制代码


*   Trending列表云函数

// 云函数入口函数
exports.main = async (event, context) => {
const { type, language, since } = event
let res = null;
let date = new Date()
if (type === ‘repositories’) {
const cacheKey = repositories::${language || 'nolang'}::${since || 'daily'};
const cacheData = await db.collection(‘repositories’).where({
cacheKey: cacheKey
}).orderBy(‘cacheDate’, ‘desc’).get()
if (cacheData.data.length !== 0 &&
((date.getTime() - cacheData.data[0].cacheDate) < 1800 * 1000)) {
res = JSON.parse(cacheData.data[0].content)
} else {
res = await fetchRepositories({ language, since });
await db.collection(‘repositories’).add({
data: {
cacheDate: date.getTime(),
cacheKey: cacheKey,
content: JSON.stringify(res)
}
})
}
} else if (type === ‘developers’) {
const cacheKey = developers::${language || 'nolang'}::${since || 'daily'};
const cacheData = await db.collection(‘developers’).where({
cacheKey: cacheKey
}).orderBy(‘cacheDate’, ‘desc’).get()
if (cacheData.data.length !== 0 &&
((date.getTime() - cacheData.data[0].cacheDate) < 1800 * 1000)) {
res = JSON.parse(cacheData.data[0].content)
} else {
res = await fetchDevelopers({ language, since });
await db.collection(‘developers’).add({
data: {
cacheDate: date.getTime(),
cacheKey: cacheKey,
content: JSON.stringify(res)
}
})
}
}
return {
data: res
}
}
复制代码


## Markdown解析

嗯,这是一个大坑。

在做技术调研的时候,发现小程序端Markdown解析主要有以下方案:

- [wxParse](
):作者最后一次提交已是两年前了,经过自己的尝试,也确实发现已经不适合如README.md的解析

- [wemark](
):一款很优秀的微信小程序Markdown渲染库,但经过笔者尝试之后,发现对README.md的解析并不完美

- [towxml](
):目前发现是微信小程序最完美的Markdown渲染库,已经能近乎完美的对README.md进行解析并展示

在Markdown解析这一块,最终采用的也是towxml,但发现在解析性能这一块,目前并不是很优秀,对一些比较大的数据解析也超出了小程序所能承受的范围,还好贴心的作者([sbfkcel](
))提供了服务端的支持,在此感谢作者的努力!

*   Markdown解析云函数

const Towxml = require(‘towxml’);
const towxml = new Towxml();

// 云函数入口函数
exports.main = async (event, context) => {
const { func, type, content } = event
let res
if (func === ‘parse’) {
if (type === ‘markdown’) {
res = await towxml.toJson(content || ‘’, ‘markdown’);
} else {
res = await towxml.toJson(content || ‘’, ‘html’);
}
}
return {
data: res
}
}
复制代码


*   markdown.js组件

import Taro, { Component } from ‘@tarojs/taro’
import PropTypes from ‘prop-types’
import { View, Text } from ‘@tarojs/components’
import { AtActivityIndicator } from ‘taro-ui’

import ‘./markdown.less’

import Towxml from ‘…/towxml/main’

const render = new Towxml()

export default class Markdown extends Component {
static propTypes = {
md: PropTypes.string,
base: PropTypes.string
}

static defaultProps = {
md: null,
base: null
}

constructor(props) {
super(props)
this.state = {
data: null,
fail: false
}
}

componentDidMount() {
this.parseReadme()
}

parseReadme() {
const { md, base } = this.props
let that = this
wx.cloud.callFunction({
// 要调用的云函数名称
name: ‘parse’,
// 传递给云函数的event参数
data: {
func: ‘parse’,
type: ‘markdown’,
content: md,
}
}).then(res => {
let data = res.result.data
if (base && base.length > 0) {
data = render.initData(data, {base: base, app: this.$scope})
}
that.setState({
fail: false,
data: data
})
}).catch(err => {
console.log(‘cloud’, err)
that.setState({
fail: true
})
})
}

render() {
const { data, fail } = this.state
if (fail) {
return (

load failed, try it again?

)
}
return (

{
data ? (




) : (



)
}

)
}
}
复制代码


## Redux

其实,笔者在该项目中,对Redux的使用并不多。一开始,笔者觉得所有的接口请求都应该通过Redux操作,后面才发现,并不是所有的操作都必须使用Redux,最后,在本项目中,只有获取个人信息的时候使用了Redux。

// 获取个人信息
export const getUserInfo = createApiAction(USERINFO, (params) => api.get(’/user’, params))
复制代码


export function createApiAction(actionType, func = () => {}) {
return (
params = {},
callback = { success: () => {}, failed: () => {} },
customActionType = actionType,
) => async (dispatch) => {
try {
dispatch({ type: ${customActionType }_request, params });
const data = await func(params);
dispatch({ type: customActionType, params, payload: data });

  callback.success && callback.success({ payload: data })
  return data
} catch (e) {
  dispatch({ type: `${customActionType  }_failure`, params, payload: e })

学习分享

在当下这个信息共享的时代,很多资源都可以在网络上找到,只取决于你愿不愿意找或是找的方法对不对了

很多朋友不是没有资料,大多都是有几十上百个G,但是杂乱无章,不知道怎么看从哪看起,甚至是看后就忘

如果大家觉得自己在网上找的资料非常杂乱、不成体系的话,我也分享一套给大家,比较系统,我平常自己也会经常研读。

2021最新上万页的大厂面试真题

七大模块学习资料:如NDK模块开发、Android框架体系架构…

只有系统,有方向的学习,才能在段时间内迅速提高自己的技术。

这份体系学习笔记,适应人群:
**第一,**学习知识比较碎片化,没有合理的学习路线与进阶方向。
**第二,**开发几年,不知道如何进阶更进一步,比较迷茫。
**第三,**到了合适的年纪,后续不知道该如何发展,转型管理,还是加强技术研究。如果你有需要,我这里恰好有为什么,不来领取!说不定能改变你现在的状态呢!

CodeChina开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》

由于文章内容比较多,篇幅不允许,部分未展示内容以截图方式展示 。

片转存中…(img-HCGyyNGf-1630666737312)]

七大模块学习资料:如NDK模块开发、Android框架体系架构…

[外链图片转存中…(img-cpLsdn2F-1630666737315)]

只有系统,有方向的学习,才能在段时间内迅速提高自己的技术。

这份体系学习笔记,适应人群:
**第一,**学习知识比较碎片化,没有合理的学习路线与进阶方向。
**第二,**开发几年,不知道如何进阶更进一步,比较迷茫。
**第三,**到了合适的年纪,后续不知道该如何发展,转型管理,还是加强技术研究。如果你有需要,我这里恰好有为什么,不来领取!说不定能改变你现在的状态呢!

CodeChina开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》

由于文章内容比较多,篇幅不允许,部分未展示内容以截图方式展示 。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值