微信小程序开发最佳实践javascript
项目地址html
在小程序之初便开发应用了,如今小程序的开发也愈来愈成熟了,完善了不少的API、组件、架构等,社区也由原来的零星点点到如今的不大不小,但也算是有了,期间也诞生了不少的开发框架,愈来愈多的三方辅助库,我也捣鼓出不少。比较有名的算是 wepy
和 labrador
,wepy
是 vue
风格的小程序开发框架,labrador
则比较亲和 React
,各有千秋,也各有深坑,而 labrador
做者目前已经中止更新了 TnT,做为React深度使用者的我来讲是忧伤的,因而我捣鼓出 wn-cli
来用类 React
快速开发微信小程序,然而在这个过程当中,想了不少,为何须要开发框架呢?小程序自己在一开始就强调框架,且如今作的也不差,后来总结了下,无非是不熟悉小程序这套框架,但学习新的中间框架去开发小程序,这不是更加加大了熟悉成本吗?且出了问题增长了处理的代价。前端
因而,我从新思考了下,最佳的微信小程序开发实践应该是无痛的,且舒服的,无痛的是指在小程序的飞速发展变动中,咱们不用重复的浪费学习第三方框架和原生框架。舒服的是指,咱们能用上咱们熟悉的流行工程流,如:less 预编译、async/await 异步请求,redux数据管理等。vue
以上,即是这个 repo 的意义与缘由。java
[x] 优化小程序 API
git
Promise
化异步接口[x] 接入 Redux
管理页面数据流github
saga
管理操做[x] 样式书写采用 less
预编译shell
Gulp
管理自动编译,持续集成[x] wxs
管理工具库json
[x] 按需加载,子页面分包(除却 tab
页面的其余页面)redux
tab
分包[x] 资源自动化管理
Promise
化异步接口因为微信的API中异步接口都是有三个回调函数的,分别是success
,fail
,complete
,执行时机同字面上意思(complete
必定会在接口的最后执行)。因而 结合Promise
,简单的描述以下:(如下为简版,具体的能够看源码)
原生微信小程序API:
wx.request({ // ... 其余一些配置项 success: () => {}, fail: () => {}, complete: () => {} });
添加Promise
后:
new Promise((resolve, reject) => { wx.request({ // ... 其余一些配置项 success: resolve, fail: reject, complete: resolve, // 这里暂取 resolve 来解决 }); });
Promise
化后,使用起来就简单了:
wx.request({ /* ...一些配置项 */}).then(res => { console.log(res) }, err => { console.error(err) })
结合下面的 async/await 就能够更加方便的书写同步代码
babel
:yarn add babel-core
env
presetsyarn add babel-preset-env
.babelrc
{ "presets": [ "env" ] }
Gulp
中使用 babel
// install yarn add gulp-babel const babel = require('gulp-babel'); // ... .pipe(babel()) // ...
runtime
,在使用async/await
的地方引入 ./src/utils/lib/runtime.js
文件,幸运的是这件事情在这个repo中的Gulp
任务中自动处理了。以上,即可以在微信小程序中使用 async/await
了。
less
预编译为何选择 less
,由于简单方便,前端编译,轻量级。
注意:因为小程序自己的限制,在书写样式的时候,不要使用 less
的嵌套功能!
// ... .pipe(addLessImport({ themePath: path.join(__dirname, './src/theme/index.less'), commomPath: path.join(__dirname, './src/app.less'), })) // ...
// ... .pipe(less({ paths: [path.join(__dirname, './src/theme')] })) // ...
// ... .pipe(rename((path) => { path.extname = '.wxss'; })) // ...
assert
文件夹,自动上传图片资源config.less
gulp.src('src/theme/config.less', { allowEmpty: true }) .pipe(file('config.less', `@cdn: ~'${config.cdn}';`)) .pipe(changed('src/theme')) .pipe(gulp.dest('src/theme'))
page { background-image: url('@{cdn}/index-bg.png'); background-attachment: fixed; }