热腾网

 找回密码
 加入热腾

QQ登录

只需一步,快速开始

搜索
热腾网 首页 腾讯手机 QQ微信 查看内容

微信小程序开发最佳实践

2018-2-2 09:44| 发布者: 热腾网| 查看: 2582| 评论: 0

摘要: 原标题:微信小程序开发最佳实践 项目地址:https://github.com/skyFi/weapp-starter 为什么会有这个 repo 在小程序之初便开发应用了,现在小程序的开发也越来越成熟了,完善了很多的API、组件、 ...

原标题:微信小程序开发最佳实践

项目地址:https://github.com/skyFi/weapp-starter

为什么会有这个 repo

在小程序之初便开发应用了,现在小程序的开发也越来越成熟了,完善了很多的API、组件、架构等,社区也由原来的零星点点到现在的不大不小,但也算是有了,期间也诞生了很多的开发框架,越来越多的三方辅助库,我也捣鼓出很多。比较有名的算是 wepylabradorwepyvue风格的小程序开发框架, labrador则比较亲和 React,各有千秋,也各有深坑,而 labrador作者目前已经停止更新了 TnT,作为React深度使用者的我来说是忧伤的,于是我捣鼓出 wn-cli来用类 React快速开发微信小程序,然而在这个过程中,想了很多,为什么需要开发框架呢?小程序本身在一开始就强调框架,且现在做的也不差,后来总结了下,无非是不熟悉小程序这套框架,但学习新的中间框架去开发小程序,这不是更加加大了熟悉成本吗?且出了问题增加了处理的代价。

于是,我重新思考了下,最佳的微信小程序开发实践应该是无痛的,且舒服的,无痛的是指在小程序的飞速发展变更中,我们不用重复的浪费学习第三方框架和原生框架。舒服的是指,我们能用上我们熟悉的流行工程流,如:less 预编译、async/await 异步请求,redux数据管理等。

以上,便是这个 repo 的意义与原因。

设计概要

  • [x] 优化小程序 API
    1. Promise 化异步接口
    2. 突破请求数量限制(队列)
  • [x] 使用 async/await
  • [x] 接入 Redux 管理页面数据流
    1. 直接接入,添加可配置项
    2. 添加 saga 管理操作
  • [x] 样式书写采用 less 预编译
    1. 使用 Gulp 管理自动编译,持续集成
  • [x] wxs 管理工具库
    1. 数据的格式化操作,如时间格式化、金币格式化等
  • [x] 按需加载,子页面分包(除却 tab 页面的其他页面)
    1. 按功能模块分包加载(推荐)
    2. 按 tab 分包
  • [x] 资源自动化管理
    1. 上传 CDN
Promise化异步接口

由于微信的API中异步接口都是有三个回调函数的,分别是 successfailcomplete,执行时机同字面上意思( complete一定会在接口的最后执行)。于是结合 Promise,简单的描述如下(以下为简版,具体的可以看源码)。

原生微信小程序API:

  1. wx.request({
  2. // ... 其他一些配置项
  3. success: () => {},
  4. fail: () => {},
  5. complete: () => {}
  6. });

添加 Promise后:

  1. new Promise((resolve, reject) => {
  2. wx.request({
  3. // ... 其他一些配置项
  4. success: resolve,
  5. fail: reject,
  6. complete: resolve, // 这里暂取 resolve 来解决
  7. });
  8. });

Promise化后,使用起来就简单了:

  1. wx.request({ /* ...一些配置项 */}).then(res => {
  2. console.log(res)
  3. }, err => {
  4. console.error(err)
  5. })

结合下面的 async/await就可以更加方便的书写同步代码。

使用 async/await

1.添加 babel

  1. yarn add babel-core

2.安装 envpresets

  1. yarn add babel-preset-env

3.使用 .babelrc

  1. {
  2. "presets": [
  3. "env"
  4. ]
  5. }

4.在 Gulp中使用 babel

  1. // install
  2. yarn add gulp-babel
  3. const babel = require('gulp-babel');
  4. // ...
  5. .pipe(babel())
  6. // ...

5.添加 runtime,在使用 async/await的地方引入 ./src/utils/lib/runtime.js文件,幸运的是这件事情在这个repo中的 Gulp任务中自动处理了。

以上,便可以在微信小程序中使用 async/await了。

样式书写采用 less预编译

为什么选择 less,因为简单方便,前端编译,轻量级。

注意:由于小程序本身的限制,在书写样式的时候,不要使用 less的嵌套功能!

1.添加 less 变量库等

  1. // ...
  2. .pipe(addLessImport({
  3. themePath: path.join(__dirname, './src/theme/index.less'),
  4. commomPath: path.join(__dirname, './src/app.less'),
  5. }))
  6. // ...

2.编译

  1. // ...
  2. .pipe(less({
  3. paths: [path.join(__dirname, './src/theme')]
  4. }))
  5. // ...

3.重命名样式文件,以便小程序识别

  1. // ...
  2. .pipe(rename((path) => {
  3. path.extname = '.wxss';
  4. }))
  5. // ...
资源自动化管理

1.目前接入阿里云,监测 assert文件夹,自动上传图片资源

2.根据配置自动生成 less 配置 config.less

  1. gulp.src('src/theme/config.less', { allowEmpty: true })
  2. .pipe(file('config.less', `@cdn: ~'${config.cdn}';`))
  3. .pipe(changed('src/theme'))
  4. .pipe(gulp.dest('src/theme'))

3.使用

  1. page {
  2. background-image: url('@{cdn}/index-bg.png');
  3. background-attachment: fixed;
  4. }

如何做一个小程序口令红包功能

写了一个时间管理的微信小程序

摩拜单车微信小程序开发技术总结


杯具

无语

很好

蛋定

愤怒

最新评论


热腾网X

未实名认证用户将不可发帖!

即日起,未实名认证用户将不可发帖,注册后,发帖请遵守当地法律法规。 【点击进行实名认证】...

点击查看详情