omi-mp - 微信小程序开发和生成 Web

通过微信小程序开发和一键生成 Web 的 H5 SPA (基于 omi + omi-router)

看下官方模板的转换例子:

Index Logs
omi-mp - 微信小程序开发和生成 Web - 图1 omi-mp - 微信小程序开发和生成 Web - 图2

因为 Web 里拉取不到用户登录态,更换了用户头像和名称。

再看下豆瓣 DEMO 转换的例子:

小程序 Web SPA
omi-mp - 微信小程序开发和生成 Web - 图3 omi-mp - 微信小程序开发和生成 Web - 图4
omi-mp - 微信小程序开发和生成 Web - 图5 omi-mp - 微信小程序开发和生成 Web - 图6

你可以在这里找到这个豆瓣小程序。

快速体验

  1. $ npm i omi-cli -g
  2. $ omi init-mp my-app
  3. $ cd my-app
  4. $ npm start
  5. $ npm run build

特别注意,由于 concurrently 不明原因起不来导致 npm start 报错,可以试着分两个命令行执行,和 npm start 同样的效果:

  1. gulp
  2. node scripts/start.js

把小程序项目拷贝到 src-mp 目录,如果是新的小程序,可以在 src-mp 目录创建小程序,目录要求:

目录说明:

  1. ├─ components //存放所有组件,每个组件一个文件夹,暂不支持乱放
  2. ├─ pages //存放所有页面,每个页面一个文件夹,暂不支持乱放
  3. ├─ index
  4. └─ logs
  5. ├─ utils
  6. ├─ app.js
  7. ├─ app.json
  8. ├─ app.wxss
  9. ├─ project.config.json

请严格按照上面目录约定,然后就可以使用小程序开发或生产 Web 了:

  1. npm start //开发
  2. npm build //发布

原理

WXML 编译

举个99乘法表的例子:

  1. compile(`
  2. <view wx:for="{{[1, 2, 3, 4, 5, 6, 7, 8, 9]}}" wx:for-item="i">
  3. <view wx:for="{{[1, 2, 3, 4, 5, 6, 7, 8, 9]}}" wx:for-item="j">
  4. <view wx:if="{{i <= j}}">
  5. {{i}} * {{j}} = {{i * j}}
  6. </view>
  7. </view>
  8. </view>`)

编译之后:

  1. function render() {
  2. return (
  3. h('div', {}, [1, 2, 3, 4, 5, 6, 7, 8, 9].map((i, index) => {
  4. h('div', {}, [1, 2, 3, 4, 5, 6, 7, 8, 9].map((j, index) => {
  5. i <= j && h('div', {}, [`${i} * ${j} = ${i * j}`])
  6. }))
  7. }))
  8. )
  9. }

WXML 会被编译成 hyperscript,并且对应的标签会被转换成 HTML 标签

WXSS 编译

编译前:

  1. view image .image{
  2. color: red;
  3. }

编译后:

  1. div img .image{
  2. color: red;
  3. }

不仅仅标签会进行替换,rpx 也会在运行时替换成 px。

小程序生命周期

页面生命周期函数

名称 描述 Omi 是否支持
onLoad 监听页面加载 支持
onShow 监听页面显示 支持
onReady 监听页面初次渲染完成 支持
onHide 监听页面隐藏 支持
onUnload 监听页面卸载 支持
onReachBottom 监听页面滚到底部 支持

组件生命周期函数

名称 描述 Omi 是否支持
created 在组件实例进入页面节点树时执行,注意此时不能调用 setData 支持
attached 在组件实例进入页面节点树时执行 支持
ready 在组件布局完成后执行,此时可以获取节点信息(使用 SelectorQuery ) 支持
moved 在组件实例被移动到节点树另一个位置时执行 支持
detached 在组件实例被从页面节点树移除时执行 支持

支持的 API

  • wx.request
  • wx.navigateTo
  • wx.getSystemInfo
  • wx.getSystemInfoSync
  • wx.setNavigationBarTitle
  • this.setData
  • this.triggerEvent

支持事件绑定,自定义事件绑定,支持 props、data 属性等等。

注意

目前不支持导入 template 标签和一些原生组件标签,需要一些时间翻译成对应的 HTML 自定义元素,欢迎试用反馈或 PR。

License

MIT @dntzhang