如何创建一个兼容「微信小程序」的Web框架:WIN
在「微信小程序」带领Web走向封闭之前,让我们创造一个Neo的种子。如果有可能的话,那么有一天,它终将成为Neo。
从微信小程序开始内测时,很多人(也包括我)都在考虑这样的问题:「微信小程序」正在让Web走向封闭。我的第一反应是:创建一个兼容「微信小程序」的Web框架——它即可以在微信上运行,也可以在Web上,还有作为一个混合应用运行。
在微信web开发者工具里,它封装了足够多的细节。我们只需要写一些我们不知道它们是如何真正工作的代码,流量都这样被截胡了。虽然,我们无法改变这个即将发生的事实,但是我们可以向那些愿意走向开放的人一个更好的解决方案。
因为「微信小程序」的框架是叫MINA,所以让我们称呼这个框架为WINV。
设计构思
基本的设计点有:
- 兼容微信小程序的语法——它并没有多少复杂的语法。只是简单的Virtual DOM操作,以及事件绑定
- 尽可能兼容大部分的微信API,兼容所有的微信API几乎是不可能的。
- 提供一个Virtual DOM转换的混合应用插件。
在之前的文章里,我们提到了MINA框架的基本原理,也差不多就是组件:
- WXML转JSON Virtual DOM组件
- Virtual DOM组件,并在这其中提供双向绑定
- UI组件转换器,即将WXML转换为Web浏览器中的标签
- UI组件,需要有一套UI组件,最好是和小程序保持一致,如WEUI
- AMD组件,提供模块化需求
- APP引擎,需要有Page模块和APP模块,来处理页面逻辑,还有Route。
一个WINV框架的Demo
计划了好几天的Demo,终于写完了,并且可以出来溜溜了~~。
这份代码在GitHub上,欢迎试玩:https://github.com/phodal/winv
并创建一个更好的出来,毕竟国庆要和我们家 ‘花仲巴’出去玩。
好了,看我们的代码,这还只是一个丑陋的原型,但是差不多可以解释了。
var App = winv.App;var Page = winv.Page;App({ onLaunch: function() { console.log('On Launch');
}
});Page({
data: {
motto: 'hello, world'
}, onLoad: function() { console.log('On Load');
}
});winv.setTemplate('<view class="container"><text class="user-motto">{{motto}}</text></view>')winv.appRun();
它在页面上的运行结果就是,输出一个 hello, world
。顺便吐槽一句,微信小程序自带的hello world不是标准的hello world。Wiki上说:
但是需要注意的是,Hello World的标准程序是“hello, world”,没有感叹号,全部小写,逗号后面有空格,与现在流行的写法并不一致。
出于原型的原因考虑,没有像MINA一样,使用大量的事件来触发,只是简单的Run:
var domJson = this.stringToDomJSON(this.template)[0];var dom = this.jsonToDom(domJson);document.getElementById('app').appendChild(dom);for (var event in window.eventPool) { window.eventPool[event]();
}
第一步,将上面的Template转化为JSON格式的Template,由DOMParser将其转换为DOM,并在这个时候添加一个Page标签。然后在转换的时候,顺便做一些更新的数据操作。 第二步,这个JSON DOM在转换成真实的DOM的时候,应该要添加事件绑定,只是还没有实现。 第三步,上面的DOM会被放到app ID里,结果就变成了
<winv-div class="page">
<winv-div class="page__hd">
<winv-view class="container">
<winv-text class="user-motto">hello, world</winv-text>
</winv-view>
</winv-div>
</winv-div>
一看就知道还有好多坑要填。
第四步,则是调用上面的on方法,写得比较简单、粗暴。
至于,对事件和数据的判断还是和MINA一致:
if('on' === option.slice(0, 2))
简单,而又粗暴。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- PAT (Basic Level) Practice (中文)1045 快速排序 (25 分)
- PAT (Advanced Level) Practice 1028 List Sorting (25分)
- CNS图表复现06—根据CellMarker网站进行人工校验免疫细胞亚群
- 【Java】03 流程控制语句
- Artwork (Gym - 102346A)【DFS、连通块】
- PAT (Basic Level) Practice (中文)1046 划拳 (15 分)
- PAT (Advanced Level) Practice 1030 Travel Plan (30分)
- PAT (Basic Level) Practice (中文)1050 螺旋矩阵 (25 分)
- PAT (Advanced Level) Practice 1031 Hello World for U (20分)
- PAT (Basic Level) Practice (中文)1051 复数乘法 (15 分)
- 【Java】06 面向对象基本特征
- PAT (Basic Level) Practice (中文)1054 求平均值 (20 分)
- zookeeper集群的搭建
- 【Java】07 常见 API
- 【Java】04 数组