微信小程序开发最佳实践
项目地址:https://github.com/skyFi/weapp-starter
为什么会有这个 repo在小程序之初便开发应用了,现在小程序的开发也越来越成熟了,完善了很多的API、组件、架构等深圳市伟恒盛电子有限公司,社区也由原来的零星点点到现在的不大不小,但也算是有了,期间也诞生了很多的开发框架,越来越多的三方辅助库,我也捣鼓出很多。比较有名的算是wepy 和 labrador, wepy 是 vue风格的小程序开发框架深圳市伟恒盛电子有限公司,labrador 则比较亲和 React,各有千秋,也各有深坑,而 labrador 作者目前已经停止更新了 TnT,作为React深度使用者的我来说是忧伤的,于是我捣鼓出 wn-cli 来用类 React快速开深圳市伟恒盛电子有限公司发微信小程序,然而在这个过程中,想了很多,为什么需要开发框架呢?小程序本身在一开始就强调框架,且现在做的也不差,后来总结了下,无非是不熟悉小程序这套框架,但学习新的中间框架去开发小程序,这不是更加加大深圳市伟恒盛电子有限公司了熟悉成本吗?且出了问题增加了处理的代价。
于是,我重新思考了下,最佳的微信小程序开发实践应该是无痛的,且舒服的,无痛的是指在小程序的飞速发展变更中,我们不用重复的浪费学习第三方框架和原生框架。舒服的是深圳市伟恒盛电子有限公司指,我们能用上我们熟悉的流行工程流,如:less 预编译、async/await 异步请求,redux数据管理等。
以上,便是这个 repo 的意义与原因。
设计概要[x] 优化小程序 API
Promise深圳市伟恒盛电子有限公司 化异步接口
突破请求数量限制(队列)
[x] 使用 async/await
[x] 接入 Redux 管理页面数据流
直接接入,添加可配置项
添加 saga 管理操作
[x] 样式书写采用 less 预编译
使用 Gulp管理自动深圳市伟恒盛电子有限公司编译,持续集成
[x] wxs 管理工具库
数据的格式化操作,如时间格式化、金币格式化等
[x] 按需加载,子页面分包(除却 tab 页面的其他页面)
按功能模块分包加载(推荐)
按 tab 分包
[x] 资源自动化管理
上传深圳市伟恒盛电子有限公司 CDN
Promise 化异步接口由于微信的API中异步接口都是有三个回调函数的,分别是 success, fail, complete,执行时机同字面上意思( complete一定会在接口的最后执行)。于是结深圳市伟恒盛电子有限公司合Promise,简单的描述如下(以下为简版,具体的可以看源码)。
原生微信小程序API:
wx.request({
// ... 其他一些配置项
success: () => {},
fail: () => 深圳市伟恒盛电子有限公司{},
complete: () => {}
});
添加 Promise后:
newPromise((resolve, reject) => {
wx.request({
// ... 其他一些配置项
succes深圳市伟恒盛电子有限公司s: resolve,
fail: reject,
complete: resolve, // 这里暂取 resolve 来解决
});
});
Promise 化后,使用起来就简单了:
wx.request({ /*深圳市伟恒盛电子有限公司 ...一些配置项 */}).then(res => {
console.log(res)
}, err => {
console.error(err)
})
结合下面的 async/await就可以更加方便的书深圳市伟恒盛电子有限公司写同步代码。
使用 async/await1.添加 babel
yarn add babel-core
2.安装 env presets
yarn add babel-preset-env
3.使用 .babelrc
"presets": [
"env"
]
}
4.在 Gulp 中使用 babel
// install
yarn add gulp-babel
const babel = require(gulp-babel);
// .深圳市伟恒盛电子有限公司..
.pipe(babel())
// ...
5.添加 runtime,在使用 async/await的地方引入 ./src/utils/lib/runtime.js 文件,幸运的是这件事情在这个repo中的 G深圳市伟恒盛电子有限公司ulp任务中自动处理了。
以上,便可以在微信小程序中使用 async/await了。
样式书写采用 less 预编译为什么选择 less,因为简单方便,前端编译,轻量级。
注意:由于小程序本身的限制,在书写样式的时深圳市伟恒盛电子有限公司候,不要使用less 的嵌套功能!
1.添加 less 变量库等
// ...
.pipe(addLessImport({
themePath: path.join(__dirname, ./src/theme/深圳市伟恒盛电子有限公司index.less),
commomPath: path.join(__dirname, ./src/app.less),
}))
// ...
2.编译
// ...
.pipe(less({
paths: [p深圳市伟恒盛电子有限公司ath.join(__dirname,./src/theme)]
}))
// ...
3.重命名样式文件,以便小程序识别
// ...
.pipe(rename((path) => {
path.extname深圳市伟恒盛电子有限公司 =.wxss;
}))
// ...
资源自动化管理1.目前接入阿里云,监测 assert 文件夹,自动上传图片资源
2.根据配置自动生成 less 配置 config.less
gulp.src(src/them深圳市伟恒盛电子有限公司e/config.less, { allowEmpty: true })
.pipe(file(config.less, `@cdn: ~${config.cdn};`))
.pipe(changed(src深圳市伟恒盛电子有限公司/theme))
.pipe(gulp.dest(src/theme))
3.使用
page {
background-image: url(@{cdn}/index-bg.png);
background-a深圳市伟恒盛电子有限公司ttachment:fixed;
}
相关文章推荐
欢迎关注 SegmentFault 微信公众号 :)





