微信小程序 框架详解及实例应用

微信官方已经开放微信小程序的官方文档和开发者工具 。前两天都是在看相关的新闻来了解小程序该如何开发,这两天官方的文档出来之后,赶紧翻看了几眼,重点了解了一下文档中框架与组件这两个部分,然后根据简易教程,做了一个常规的todo app 。这个app基于微信小程序的平台,实现了todo app的常规功能,同时为了让它更接近实际的工作场景,也用到了loading与toast这两个组件来完成一些操作的交互与反馈 。这个平台给我的直观感受是,技术层面,它跟vue有相似性,但是远没有vue强大;开发时候的思路,不像vue,反倒觉得比较像backbone 。所以要是使用过backbone,vue等mvc,mvvm框架的人,会觉得这个平台上手很容易 。本文主要介绍这个todo app实现的一些要点 。
【微信小程序 框架详解及实例应用】先补充下本文相关的资料:
官方文档:https://mp.weixin.qq.com/debug/wxadoc/dev/index.html
官方开发者工具下载:https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/download.html
本文todo app的功能演示:

微信小程序 框架详解及实例应用

文章插图
注:需长按todo的text,才能直接编辑 。因为是在手机端,所以不能使用双击事件来进行编辑,改成了长按事件 。小程序的平台也没有提供双击事件的绑定 。
相关源码:https://github.com/liuyunzhuge/blog/tree/master/todos/wx
如果你想在本地运行这个项目,需要先安装开发者工具,按照文档中简易教程的描述,先建好一个项目;
建完之后,开发者工具就会打开这个项目;
接着在磁盘上,找到建好的项目的文件夹,把里面的内容都删掉,把上面源码文件夹下的文件都粘贴进去;
然后重新打开开发者工具,先进入到编辑页签,然后点击编译按钮,就会直接进入到调试界面,查看app的功能:
微信小程序 框架详解及实例应用

文章插图
下面来介绍下这个app开发的要点:
1. 这个app的目录结构以及配置等就不详细介绍了,这些在文档-框架部分都有很详细的描述 。这个平台里面没有html和css,取而代之的是wxml和wxss 。wxss跟css几乎没有区别,缺点就是不如css强大,支持的选择器有限 。但是好处是由于只有微信这一个平台,所以几乎没有兼容性问题,能够使用标准的,更新的css技术 。wxml里面只能用平台提供的那些组件的标签,html的标签不能直接用,各个组件的在wxml的使用方式,都可以在文档-组件这一部分找到说明的示例 。所以实际上wxml跟wxss编写起来都没有什么难题 。
2. wxml支持以下这些特性:
微信小程序 框架详解及实例应用

文章插图
在todo app里面除了模板和引用没有用到之外,其它的都使用到了,不过没有使用到每个特性的各个细节,只根据app的需要选用合适的功能 。前几天看到有文章说,微信小程序可能是基于vue框架来实现的,所以就看了下vue的文档 。对于数据绑定,条件渲染,列表渲染,事件这几部分都详细看了vue的用法 。对比下来,wxml提供的这些特性,跟vue的相关特性是还比较像,不过功能并没有那么多,所以也不能轻易地直接拿vue框架的特性用到小程序里面 。优秀实践,还是基于官方文档中提供的说明来,如果官方文档中没有提到的功能,通过猜测的方式去用,肯定是行不通的 。我通过打印的方式,查看一些对象的原型,也并没有发现比官方文档要多的一些实例方法,说明小程序的框架功能确实是有限的 。
3. wxss其实是可以用less或者sass来写的,只要选择器满足框架的要求即可 。由于时间原因,就没有在这个app里面去尝试了 。

推荐阅读