taro3.x + tailwindcss + zustand微信小程序模板

写在前面

本项目没有适配多端,只是为了微信小程序开发搭建的模板项目。

对其他小程序的适配可以自行比较官方示例仓库添加依赖和代码,除了H5以外的适配都比较简单。

背景

近期有微信小程序开发需求,主管让我们进行技术选型、编写开发指引和规范文档。这里记录一下我们的技术选型过程,并分享一个空的只包含主要依赖工具的模板项目供开发朋友们参考。

技术选型

框架 UI库 样式方案 状态管理
Taro3.x(React18、Webpack5) @antmjs/vantui weapp-tailwindcss zustand

原生 or Taro or uni-app

毫无疑问,对于没有跨端需求的我们,写原生必然是性能和可扩展性最好的方案。uni-app也是大多数人首选的小程序开发框架,对比Taro,其拥有更大的使用用户、更丰富的生态,还有我没测试过,但是社区反馈的更好的性能。但是鉴于我们已经存在使用Taro开发的小程序项目没有出现明显的性能短板,且只有Taro支持React写法,另外主管倾向于不引入新的前端框架增加学习成本。所以我们还是选择了使用Taro搭建项目模板。

Taro官方团队已经推出Taro 4.x,支持了vite编译、开发鸿蒙应用等功能。不过鉴于我们对vite编译带来的性能优化(个人感觉很奇怪,当前小程序都是全量编译后才能在开发者工具上运行的,vite的异步加载js的性能优势该怎么体现出来呢?)和鸿蒙等功能没有硬需求,且Taro团队仍会继续就框架的问题修复和性能优化支持维护一段时间,所以还是倾向于选择相对稳定的3.x版本。

UI组件库

在以往的支付宝小程序开发经历中,发现了该@antmjs/vantui组件库对于Taro(React)的支持较好、组件丰富度也比官方推荐的几个组件库优秀,且维护团队回答问题、解决bug很及时。所以在后续的小程序开发中选择采用该组件库作为小程序模板项目的组件库。

模板代码也是参考AntmJS/pure-project-vantui修改而来,对于H5或其他小程序的适配可以参考该工程。

样式方案

我们PC端项目已经很普遍地在使用tailwindcss,原子化CSS带来的开发爽感本人深有体会,果断选择继续引入tailwindcss,官方已经给出了引入方案:使用 Tailwind CSS | Taro 文档。引入weapp-tailwindcss,并按要求配置即可体验。

状态管理

React项目的状态管理工具五花八门。Taro官方文档介绍的是Redux,个人感觉Redux太重、太繁琐,果断转向选择了广受社区好评的zustand,自己也在项目中使用过,配置方便,引入简单,也可以在React之外使用,方便扩展。参考welives大佬的Taro-React工程搭建 | 学习笔记成功引入了zustand,并扩展了可以通过TaroAPI实现持久化的功能。

代码仓库

大致框架代码可以查看 HyaCiovo/taro-wxapp-template: taro3.6 + react18 + @antmjs/vantui + zustand + tailwindcss 微信小程序模板代码

相关推荐
活宝小娜40 分钟前
vue不刷新浏览器更新页面的方法
前端·javascript·vue.js
程序视点43 分钟前
【Vue3新工具】Pinia.js:提升开发效率,更轻量、更高效的状态管理方案!
前端·javascript·vue.js·typescript·vue·ecmascript
coldriversnow44 分钟前
在Vue中,vue document.onkeydown 无效
前端·javascript·vue.js
我开心就好o1 小时前
uniapp点左上角返回键, 重复来回跳转的问题 解决方案
前端·javascript·uni-app
开心工作室_kaic2 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
刚刚好ā2 小时前
js作用域超全介绍--全局作用域、局部作用、块级作用域
前端·javascript·vue.js·vue
沉默璇年3 小时前
react中useMemo的使用场景
前端·react.js·前端框架
yqcoder3 小时前
reactflow 中 useNodesState 模块作用
开发语言·前端·javascript
2401_882727573 小时前
BY组态-低代码web可视化组件
前端·后端·物联网·低代码·数学建模·前端框架
SoaringHeart4 小时前
Flutter进阶:基于 MLKit 的 OCR 文字识别
前端·flutter