微信小程序分析

Posted 木森焱

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了微信小程序分析相关的知识,希望对你有一定的参考价值。

微信小程序是一种新兴并且很火热的事物,它类似于浏览器的扩展程序和移动端的App应用,又和浏览器的网页很相像。之所以这样说,是因为微信小程序它可以实现扩展和App的功能,但却不需要下载和安装,只需要利用微信搜索或扫描二维码即可打开。既给用户手机节省了内存,又让用户可以体验App的功能,估计这也是微信小程序如此之火的原因。下边我们就微信小程序的原理、优势及劣势进行详细的分析。

原理:

微信小程序采用javascript、WXML、WXSS三种技术进行开发,从技术讲和现有的前端开发差不多,但深入挖掘的话却又有所不同。

JavaScript:首先JavaScript的代码是运行在微信App中的,并不是运行在浏览器中,因此一些H5技术的应用,需要微信App提供对应的API支持,而这限制住了H5技术的应用,且其不能称为严格的H5,可以称其为伪H5,同理,微信提供的独有的某些API,H5也不支持或支持的不是特别好。

WXML:WXML微信自己基于XML语法开发的,因此开发时,只能使用微信提供的现有标签,html的标签是无法使用的。

WXSS:WXSS具有CSS的大部分特性,但并不是所有的都支持,而且支持哪些,不支持哪些并没有详细的文档。

微信的架构,是数据驱动的架构模式,它的UI和数据是分离的,所有的页面更新,都需要通过对数据的更改来实现。具体架构如图:

上图把小程序分为两个部分webview和appService。其中webview主要用来展现UI,appService有来处理业务逻辑、数据及接口调用。它们在两个进程中运行,通过系统层JSBridge实现通信,实现UI的渲染、事件的处理。

优势:

1、无需下载,通过搜索和扫一扫就可以打开。

2、良好的用户体验:打开速度快。

3、开发成本要比App要低。

4、安卓上可以添加到桌面,与原生App差不多。

5、为用户提供良好的安全保障。小程序的发布,微信拥有一套严格的审查流程, 不能通过审查的小程序是无法发布到线上的。

劣势:

1、限制较多。页面大小不能超过1M。不能打开超过5个层级的页面。

2、样式单一。小程序的部分组件已经是成型的了,样式不可以修改。例如:幻灯片、导航。

3、推广面窄,不能分享朋友圈,只能通过分享给朋友,附近小程序推广。其中附近小程序也受到微信的限制。

4、依托于微信,无法开发后台管理功能。

以上是关于微信小程序分析的主要内容,如果未能解决你的问题,请参考以下文章

[技术分析] 微信小程序框架全解脑图,一张图看清组件构造

微信小程序框架分析小练手——天气微信小程序制作

从程序员的角度分析微信小程序

微信小程序项目开发总结

微信小程序现状分析

微信小程序都有啥功能?