搜索
首页微信小程序小程序开发小程序框架如何选择
小程序框架如何选择Jan 27, 2021 am 09:39 AM
小程序

小程序框架如何选择

导语:

从小程序开始内测一直到现在,各个公司对小程序业务的开发需求越来越大。开发者在使用原生去开发小程序时很难受,尤其是遇上业务比较复杂的项目,如果仍然使用原生开发,会变得很难去管理和迭代。

(学习视频分享:编程入门

使用原生开发的问题:

  • 小程序本身不支持常用的css预编译器

  • 不支持ES7以上的高级语法,如async await等特性;

  • 不支持工程化,如环境、变量等管理

  • 缺少统一的request拦截请求

  • 缺少统一的本地缓存读取管理

使用框架可以解决的问题:

  • 支持css预编译器

  • 支持ES7以上语法

  • 支持工程化

  • 大部分框架支持多端,一套代码多端复用

框架介绍与对比

Wepy

WePY (发音: /'wepi/)是一款让小程序支持组件化开发的框架,通过预编译的手段让开发者可以选择自己喜欢的开发风格去开发小程序。框架的细节优化,Promise,Async Functions的引入都是为了能让开发小程序项目变得更加简单,高效

d83fef8cf2581cd2241239e201ea1c6.png

Mpvue

mpvue 是一个使用 Vue.js 开发小程序的前端框架。框架基于 Vue.js 核心,mpvue 修改了 Vue.js 的 runtime 和 compiler 实现,使其可以运行在小程序环境中,从而为小程序开发引入了整套 Vue.js 开发体验。

主要特性

  • 彻底的组件化开发能力:提高代码复用性

  • 完整的 Vue.js 开发体验

  • 方便的 Vuex 数据管理方案:方便构建复杂应用

  • 快捷的 webpack 构建机制:自定义构建策略、开发阶段 hotReload

  • 支持使用 npm 外部依赖

  • 使用 Vue.js 命令行工具 vue-cli 快速初始化项目

  • H5 代码转换编译成小程序目标代码的能力

Taro

Taro 是一套遵循 React 语法规范的 多端开发 解决方案

88e5bd6debdc8d207a773bfc18b4275.png

Uni-app

uni-app 是一个使用 Vue.js 开发跨平台应用的前端框架。

dd9f9e6683faaed96f7db9b2409bba5.png

Chamelon

Chameleon/kəˈmiːlɪən/,简写CML,中文名卡梅龙;中文意思变色龙,意味着就像变色龙一样能适应不同环境的跨端整体解决方案。

主要特性

目录结构:提供规范化的项目结构,适合于企业级大型应用的开发。

视图层:视图层由CML与CMSS编写,核心是一个标准响应式数据驱动视图更新。

逻辑层:逻辑层由javascript编写,逻辑层将处理数据后自动更新视图,提供视图层的事件响应方法。

多态协议:提供了跨端时各端底层组件与接口统一的解决方案。

规范校验:为了提高开发的效率与代码的可维护性,提供了全面的代码规范与校验。

框架对比

eb4bae979853cdfbd6cf83fcd120dc2.png

star数量记录于2019-09-17

框架优缺点分析

wepy

优点:微信团队提供的框架,对微信小程序的支持度高,可工程化开发项目,组件和相关文档内容丰富,论坛和交流社区活跃

缺点:只支持微信小程序,支持端单一,框架本身静态编译,动态repeat时会出现比较严重的 BUG,语法解析有时会出现错误,错误处理还比较简单

mpvue

优点:开源时间最早的多端框架,网上相关的问题和例子较多,适用于工程化和组件化开发项目

缺点:开发团队基本不再维护该框架,使用者数量越来越少,且框架本身存在的各种问题经过长时间的迭代依旧没有解决

taro

优点:支持端能力丰富,开发团队维护力度大,论坛和官方的问题解决速度快,本身基于微信小程序API开发,微信小程序的支持能力强大

缺点:本身是文件的静态编译,复杂代码的转换的上会产生问题,对H5和移动端的端兼容能力比较差

uni-app

优点:开发团队主推的框架,论坛和交流社区非常活跃,端的兼容能力异常强大,存在特定IDE去兼容框架代码的书写规范

缺点:部分代码未开源,官方问题反馈速度不及时,编辑器绑定

chameleon

优点:规划完整,统一的多态协议,渐进式跨端,提供了基础开发脚手架命令工具,帮助端开发者从开发、联调、测试、上线等全流程高效的完成业务开发

缺点:开源时间短,相关的资料和问题解决方法较少,端兼容能力还待完善

选型分析

现有的小程序框架很多,在项目开发中选型要根据业务和项目本身的实际情况选择

兼容微信小程序

如果只是兼容微信小程序,使用wepy、taro、chameleon都可以,因为这些框架的API都是基于微信小程序的,所以对微信小程序的兼容性基本和原生差不多,vue系的开发者可以选择wepy、chameleon,react系的开发者可以选用taro。当然一下开发者为了轻便的开发可以使用glup做工程化以原生的进行开发,不过框架本身虽然增加了包的大小,但是框架在原生基础上会封装一下性能优化的点,如setData的重复渲染等。

不选mpvue的原因是因为mpvue的开发团队已不再维护,而且mpvue在兼容微信小程序的复杂业务上也存在部分问题一直没有解决。

不选uni-app的原因只有一个,不喜欢使用HBuildX

兼容多端

如果是要兼容多端的话,可以根据兼容端能力的需求选择taro或者chameleon,chameleon虽然开源时间短,但是统一多态协议这个设计理念确实很不错。taro是凹凸实验室重点推广的项目,在使用过程中可以发现论坛的反馈和交流群的恢复速度还是很及时的,使用taro可以很好的兼容微信小程序,如果要兼容其他端需要在代码根据端进行特殊处理

总结

小程序框架选型,不过选择什么框架,最后都会编译成小程序可识别的代码运行在微信客户端,根据业务需求选择小程序框架要搞清楚小程序原生的能力。最后不得不吐槽一下微信开发文档的粗糙,很多关键的点描述的都不是很详细。

相关推荐:小程序开发教程

以上是小程序框架如何选择的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:掘金。如有侵权,请联系admin@php.cn删除
使用Python开发微信小程序使用Python开发微信小程序Jun 17, 2023 pm 06:34 PM

随着移动互联网技术和智能手机的普及,微信成为了人们生活中不可或缺的一个应用。而微信小程序则让人们可以在不需要下载安装应用的情况下,直接使用小程序来解决一些简单的需求。本文将介绍如何使用Python来开发微信小程序。一、准备工作在使用Python开发微信小程序之前,需要安装相关的Python库。这里推荐使用wxpy和itchat这两个库。wxpy是一个微信机器

小程序能用react吗小程序能用react吗Dec 29, 2022 am 11:06 AM

小程序能用react,其使用方法:1、基于“react-reconciler”实现一个渲染器,生成一个DSL;2、创建一个小程序组件,去解析和渲染DSL;3、安装npm,并执行开发者工具中的构建npm;4、在自己的页面中引入包,再利用api即可完成开发。

用Python编写简单的聊天程序教程用Python编写简单的聊天程序教程May 08, 2023 pm 06:37 PM

实现思路x01服务端的建立首先,在服务端,使用socket进行消息的接受,每接受一个socket的请求,就开启一个新的线程来管理消息的分发与接受,同时,又存在一个handler来管理所有的线程,从而实现对聊天室的各种功能的处理x02客户端的建立客户端的建立就要比服务端简单多了,客户端的作用只是对消息的发送以及接受,以及按照特定的规则去输入特定的字符从而实现不同的功能的使用,因此,在客户端这里,只需要去使用两个线程,一个是专门用于接受消息,一个是专门用于发送消息的至于为什么不用一个呢,那是因为,只

Java语言中的微信小程序开发介绍Java语言中的微信小程序开发介绍Jun 09, 2023 pm 10:40 PM

微信小程序是一种轻量级的应用程序,可以在微信平台上运行,不需要下载安装,方便快捷。Java语言作为一种广泛应用于企业级应用开发的语言,也可以用于微信小程序的开发。在Java语言中,可以使用SpringBoot框架和第三方工具包来开发微信小程序。下面是一个简单的微信小程序开发过程。创建微信小程序首先,需要在微信公众平台上注册一个小程序。注册成功后,可以获取到

教你如何在小程序中用公众号模板消息(附详细思路)教你如何在小程序中用公众号模板消息(附详细思路)Nov 04, 2022 pm 04:53 PM

本篇文章给大家带来了关于微信小程序的相关问题,其中主要介绍了如何在小程序中用公众号模板消息,下面一起来看一下,希望对大家有帮助。

PHP与小程序的地理位置定位与地图显示PHP与小程序的地理位置定位与地图显示Jul 04, 2023 pm 04:01 PM

PHP与小程序的地理位置定位与地图显示地理位置定位与地图显示在现代科技中已经成为了必备的功能之一。随着移动设备的普及,人们对于定位和地图显示的需求也越来越高。在开发过程中,PHP和小程序是常见的两种技术选择。本文将为大家介绍PHP与小程序中的地理位置定位与地图显示的实现方法,并附上相应的代码示例。一、PHP中的地理位置定位在PHP中,我们可以使用第三方地理位

小程序中文件上传的PHP实现方法小程序中文件上传的PHP实现方法Jun 02, 2023 am 08:40 AM

随着小程序的广泛应用,越来越多的开发者需要将其与后台服务器进行数据交互,其中最常见的业务场景之一就是上传文件。本文将介绍在小程序中实现文件上传的PHP后台实现方法。一、小程序中的文件上传在小程序中实现文件上传,主要依赖于小程序APIwx.uploadFile()。该API接受一个options对象作为参数,其中包含了要上传的文件路径、需要传递的其他数据以及

PHP与小程序的第三方登录与绑定功能实现PHP与小程序的第三方登录与绑定功能实现Jul 04, 2023 am 08:57 AM

PHP与小程序的第三方登录与绑定功能实现随着互联网的发展和智能手机的普及,小程序成为了移动应用程序开发的热门选择。小程序不仅提供了优秀的用户体验,还具备各种强大的功能。其中,第三方登录与绑定是小程序中常见的功能之一。本文将介绍如何使用PHP与小程序实现第三方登录与绑定的功能,并为读者提供代码示例。第三方登录是指用户可以使用其他平台的账号信息登录到目标平台,而

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能