Skip to content

JoweiBlog/wechat-miniprogram-dev

Repository files navigation

微信小程序开发经验+

总结了一些开发微信小程序过程中遇到问题的解决方式/经验分享,另外共享几个通用组件

!!!小程序迭代较快,有些内容已过时或有更好的替代方案,酌情参考。


# cache

为什么需要cache工具?

  • 微信api提供了storage, 类似 localStorage 永久性存储? (除用户主动删除或超一定时间被自动清理)
  • 希望可以提供类似 sessionStorage 的模拟,当次打开小程序/热启动内(本次使用期间)有效(冷启动清理)
  • 希望某个缓存一定时间内有效,类似 expire cookie
  • 可以更新expire缓存,但不改变其过期时间
import $cache, * as caches from 'path/to/./libs/cache.js'

 // localstorage 
 $cache.set('key', 1)
 $cache.get('key')   // 1
 
 // localstorage expire
 $cache.set('key', 1, 10000)
 $cache.get('key')   // 1, 10s内访问有效
 
 // localstorage  延续上次缓存时间,若上次没缓存,此次设置也将取消
 $cache.set('key', 1, true)
 $cache.get('key')   // 1
 
 // sessionstorage 
 $cache.session.set('key', 1)
 $cache.session.get('key')   // 1
 
 // remove 
 $cache.remove('key')
 $cache.session.remove('key')

# PageModal

路由页面间的相互通信(限已存在路由历史记录中的路由) : App 已注入 pages: new PageModal()

// page A
Page({
  data: {
    log: 'ori log content'
  },
  //..
  changeLog () {
    this.setData({ log: 'log changed.' })
  },
  onLoad() {
    // 页面栈, 建议:仅需要通信的页面加入栈中
    getApp().pages.add(this)
  },
  onUnload() {
    // 页面卸载关闭
    getApp().pages.delete(this)
  }
})

// page B
Page({
  //...
  doSomething() {
    // ..
    // 调起 page A  / changeLog
    getApp().pages.get('path/to/A').changeLog()
  },
})

# page decorator

Page 装饰器实例,可扩展为mixin (组件已提供behaviors,不必要时不用mixin) : App 已引用 import 'libs/pageDecorator.js'

// Page 装饰器实例 pageDecorator.js
const oriPage = Page

export default Page = (data) => {

  // PV统计
  const onLoad = data.onLoad;
  data.onLoad = function(...args) {
    RecordPV.call(this)
    // do something before oriPage onLoad
    // ..
    return onLoad && onLoad.call(this, ...args)
  }

  oriPage(data)
}

// Record PV
function RecordPV() {
  console.log('view the page : ', this.route)
  // sync serve..
  // fetch(apis.pv, data: { page: this.route })
}

# fetch

封装请求,api模块化 ; tip: 目的只是为了简化wx.request,统一作部分rule code拦截,以及error处理; 因业务场景不同,已取消 promise风格化重试机制auth请求加锁请求取消

// req
import fetch, { apis } from 'path/to/./core/fetch.js'

Page({
  req () {
    fetch({
      ...apis.order.getOrderList,
      data: {
        page: 1,
        page_size: 10
      },
      succ: (res) => {
        console.log(res)
      },
      fail: (err) => {
        console.log(err)
      },
      done: () => {
        console.log('done')
      }
    })
  }
})

# utils

Event Description
typeOf() 类型
throttle() 节流
formatDate() 格式化日期
numberCal 浮点计算
pick() 复制部分属性

# 倒计时组件

提供简易倒计时功能

Props Type Description
time Number 时间(秒)
format String 格式化显示, 默认:dd天hh时mm分ss秒
timeStyle String 时间style样式;默认: '' (::font/color 等可继承父级,一般不用配置)
symbolStyle String 时间symbol样式:默认:'' (::font/color 等可继承父级,一般不用配置)
sign String 同时使用多个 countdown 组件时,需要 sign 标注唯一,通知时会回传sign
Event Description
running() 倒计时进行中, 返回:{ sign, time }// time: 实时计时(s)
end() 倒计时结束后执行,返回:{ sign }

# 级联选择组件

提供弹窗形式cascader

Props Type Description
display Boolean 显示/隐藏
options Object 源数据
props Object 可配置 级联 属性名, 默认:{ label: 'label', value: 'value', children: 'children' }
_default Array 可设置默认选择项; 默认 []
Event Description
close() 选择器关闭触发
 *  close
 *  @return
 *  { 
 *    type: 'cancel',  // cancel: 取消选择/点击遮罩层; submit: 确认
 *    valueIns: [],     // 返回已选择的下标;(深度层级)
 *    valueArr: [],     // 返回已选择的下标对应 option 内容
 *  }

# 自定义navigationBar

# 尝试WeUI组件: mp-navigation-bar

~~组件为自定义navigationBar实例,暂无复杂配置,通常也不建议在navigationBar做过多业务/UI; 提供了三种模式参考,自定义单点 模拟微信后退 模拟微信菜单 可依据自身业务自行定义。 提示:目前(19/5/13前)获取菜单位置api 开发工具与真机结果有差别,注意调试;

~~> 自定义单点

~~> 模拟微信后退

~~> 模拟微信菜单

Props Description
background 背景色

~~> bar跟随滚动淡出实例.


# 预检授权组件 && WxAuth

提前检查授权状态,(已)授权后将完成原有操作

  • 解决获取权限场景
  • 授权成功回调
  • 组件默认强制授权继续操作,可在基础上优化改进用户体验
  • 需要配合WxAuth桥接组件,详细查看demo
Props Type Description
display Boolean 显示/隐藏,提供该属性仅用与WxAuth控制显隐组件
scope String 微信scope权限值, 如:scope.userLocation
Event Description
success() 授权成功: { scope, [result: { detail, [code] }] }

detail: userinfo / userPhone 时会返回detail信息 code: login code(session 过期才会重新获取)

// Mng
const recorderMng = wx.getRecorderManager()

// 录音
record() {
  // 检查授权
  this.wxa.checkScope({
    scope: 'scope.record',
    done() {
      console.log('finish record auth,');
      // 现在可以用 recorderMng api 咯
      // recorderMng.start({
      //   duration: 60000,
      //   format: 'mp3'
      // })
    }
  })
}

# 生成海报组件

配置生成海报

  • 方便前端配置生成简单海报
  • 提供 Block Image Text 三种模式, 以及Color纯色、渐变等模式配置
  • config => canvas => image
  • 组件属性值较多,详细Config查看组件内注释文档
  • 暂不支持本地图片
  • 真机暂不支持自定义字体

Props

Props Type Description
config Object Config配置, 详细见下表
autoMake Boolean 自动生成 ? 点击slot生成

Config

Config Type Description
width Number 画布宽度
height Number 画布高度
bgColor String Object 画布背景色 Color
block Array 占位配置 [...Block]
image Array 图片配置 [...Image]
text Array 文字配置 [...Text]

Module

Module Type Description
Block Object 占位配置(文档)
Image Object 图片配置(文档)
Text Object 文字配置(文档)
Color String Object 颜色模式,纯色、渐变等

点击生成海报实例.

Releases

No releases published

Packages

No packages published