Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yill625/taro3-vue3-template
一个基于 Taro3 和 Vue3 框架微信小程序模版。 核心技术采用Taro3、Vue3、TypeScript、NutUi、Vux4/Pinia、VueUse
https://github.com/yill625/taro3-vue3-template
eslint mini-program nutui pinia prettier taro taro-demo taro-ui taro3 typescript vant vue vue3 vue3-composition-api vue3-demo vue3-typescript vuex4 wechat-app wechat-mini-program xcx
Last synced: 3 days ago
JSON representation
一个基于 Taro3 和 Vue3 框架微信小程序模版。 核心技术采用Taro3、Vue3、TypeScript、NutUi、Vux4/Pinia、VueUse
- Host: GitHub
- URL: https://github.com/yill625/taro3-vue3-template
- Owner: Yill625
- Created: 2021-11-12T07:00:28.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-01-02T07:42:30.000Z (about 2 years ago)
- Last Synced: 2025-02-17T07:09:23.325Z (4 days ago)
- Topics: eslint, mini-program, nutui, pinia, prettier, taro, taro-demo, taro-ui, taro3, typescript, vant, vue, vue3, vue3-composition-api, vue3-demo, vue3-typescript, vuex4, wechat-app, wechat-mini-program, xcx
- Language: JavaScript
- Homepage:
- Size: 8.91 MB
- Stars: 229
- Watchers: 7
- Forks: 54
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# 使用 Taro3 + Vue3 + TypeScript + NutUi + Pinia 开发微信小程序
> 🏆 有关于任何小程序问题欢迎提 Issues
## 准备工作:Vscode 插件安装
- Eslint
- Prettier
- Volar## 如何使用
1. 克隆项目
```bash
git clone https://github.com/Yill625/taro3-vue3-template.git
```2. 进入项目目录安装依赖
```bash
cd taro3-vue3-template
yarn install
```3. 运行小程序开发编译
```bash
yarn dev:weapp
```4. 打开微信开发工具 项目目录指向 dist 目录 填写自己的 AppId 或者使用测试 AppId
## 最新更新 taro 3.5.7 (2022.11)
### [ Taro3.5 指南](https://docs.taro.zone/blog/2022/07/26/Taro-3.5)
1. taro update self 3.5.7
2. taro update project 3.5.7
3. vue3 add @vue/babel-plugin-jsx @tarojs/plugin-framework-vue3### Webpack5
```bash
yarn remove @tarojs/mini-runner @tarojs/webpack-runneryarn add @tarojs/webpack5-runner
```
### Pinia
data:image/s3,"s3://crabby-images/8a38c/8a38cef8baf87f76e0954991be2aaa7912afaec7" alt=""
[pinia 报错](https://github.com/vuejs/pinia/pull/967)```bash
# 升级 pinia
yarn upgrade pinia --latest
```### webpack5 开启持久化缓存
首次编译
data:image/s3,"s3://crabby-images/cbc14/cbc145dfe52a026bf9eff0c54fdded808b37288c" alt=""
第二次编译
data:image/s3,"s3://crabby-images/f5acf/f5acf220ad6e0c5bedeab9721c82b17ace4795eb" alt=""### NutUi
```bash
yarn upgrade @nutui/nutui-taro --latest
```## 升级 taro 3.4.0 (2021.10)
- 支持 Composition API 版本的小程序生命周期钩子 [文档](https://docs.taro.zone/docs/next/composition-api)
- 支持 `` v-bind 语法
- 暴露 VueLoader 的配置 [文档](https://docs.taro.zone/docs/next/vue3#compileroptions)
- 新增 defineAppConfig 与 definePageConfig 编译宏## 当前实现了的功能
- Taro3 Vue3 Ts ~~Vux4~~ Pinia
- 组件库 NutUI
- Eslint Prettier CommitLint
- 小程序分包配置
- Taro3 配合 Vue DevTools 调试
- 样式封装 1px 问题 底部安全区域适配# 本项目的搭建过程
## 一、Taro 基本安装
[Taro 文档](https://taro-docs.jd.com/taro/docs/GETTING-STARTED)
```shell
npx @tarojs/cli init WechatAppDemo
```> 使用 npx 可以不用全局先安装 cli 工具,直接下载最新 Taro3 工程
data:image/s3,"s3://crabby-images/cac2d/cac2dcaf4e826703a515102ed0c555026bf39b3a" alt=""
本地安装 cli 确保项目基本运行
```shell
# 安装cli 用来执行构建等操作
yarn add @tarojs/cli
# 预览
yarn dev:weapp
```> 打开微信开发工具 工程目录需要指向构建出来的 dist 文件
data:image/s3,"s3://crabby-images/a471c/a471cc899ad162ed8c0e7a22223eb9d544488a88" alt=""
data:image/s3,"s3://crabby-images/b74b4/b74b4ec3154a9527ce9c073d67476068baeb66ab" alt=""
## 二、设置代码规范的 Eslint Prettier CommitLint
- 代码规范 ESlint
- 代码格式化 Prettier
- 提交规范 CommitLint### 1.安装依赖
```shell
yarn add @vue/eslint-config-prettier @vue/eslint-config-typescript eslint-plugin-prettier -D
```### 2.解决 Eslint 和 Prettier 的冲突需设置.eslintrc.js 和 .prettierrc
### 3.添加 Ts 检查命令,确保符合 Ts 规范 。添加 Eslint 检查命令,确保符合 Eslint 规范
```shell
yarn add vue-tsc -D
```在 package.json 中 script 添加命令
```json
"scripts":{
"tsc": "vue-tsc --noEmit --skipLibCheck",
"lint": "eslint --ext .vue --ext .js --ext .ts src/"
}
```data:image/s3,"s3://crabby-images/c9684/c9684c36e588fc4c5912d4b10428269da6ebfd25" alt=""
### 4.添加 husky 触发 Git 钩子来保证代码提交时 Ts 检查和 Eslint 检查都符合规范
```shell
# https://github.com/typicode/husky
# https://typicode.github.io/husky/#/?id=articles
yarn add husky -D
# 初始化 husky
npx husky install
# 测试命令
npx husky add .husky/pre-commit "echo test"
```data:image/s3,"s3://crabby-images/8e5a6/8e5a614ea3e5c26bbaa3d21a746abb311c59a6f9" alt=""
编辑 pre-commit 执行 Eslint 检查和 Ts 检查
data:image/s3,"s3://crabby-images/14a1a/14a1a6a81cda5a2dc3db047a51b2778c820f4e0e" alt=""
### 5. 配置 [commitlint](https://github.com/conventional-changelog/commitlint) 提高提交时的规范
```shell
yarn add @commitlint/{config-conventional,cli} -D
# Configure commitlint to use conventional config
echo "module.exports = {extends: ['@commitlint/config-conventional']}" > commitlint.config.js
# Add hook
npx husky add .husky/commit-msg 'npx --no -- commitlint --edit "$1"'
# 首次安装不起作用可以运行 npx husky install
```## 在 Taro3 Vue3 小程序中使用 nutui
> [Nutui](https://nutui.jd.com/#/) 京东风格的轻量级移动端 Vue 组件库
```shell
yarn add @nutui/nutui-taro
```安装 nutui 会遇到样式的报错 如图
data:image/s3,"s3://crabby-images/01558/015580e2076aee41f498f0c3f482f3b5a67fd11c" alt=""解决办法:引入 @tarojs/plugin-html 插件 https://taro-docs.jd.com/taro/docs/use-h5
全局引入后的依赖大小
data:image/s3,"s3://crabby-images/c91fe/c91fe285c905bcf34cfeafc2a2c4a813fa9b8a40" alt=""为了按需引入,先安装插件 babel-plugin-import
```shell
# https://nutui.jd.com/#/starttaro
yarn add babel-plugin-import -D
```按需引入后的主包大小
```js
import { createApp } from 'vue'
import App from './App.vue'
import { Button, Cell, Icon } from '@nutui/nutui-taro'
import '@nutui/nutui-taro/dist/style.css'
createApp(App).use(Button).use(Cell).use(Icon)
```data:image/s3,"s3://crabby-images/25b58/25b584e20bbb9ecfe77e3f0f0a8094b61323f1af" alt=""
样式处理 因为 nutui 的设计稿是 375 的 所以将框架的设计尺寸调整为 375
data:image/s3,"s3://crabby-images/e9d79/e9d79566cb2b98953f3f04582a26f0d4b00866d7" alt=""到这里 nutui 组件库已经采坑完毕 能够正常使用 事件调用正常
data:image/s3,"s3://crabby-images/8fac8/8fac836fa4fc39058f960b2a492eef65a999dd1b" alt=""
> nutui 事件不触发 是因为 @tarojs/plugin-html 版本不对 我当前这个项目固定设置为 3.3.12 如果设置为最新 3.3.13 则不行
## 小程序分包配置
> 随着业务代码和组件的引入越来越多,主包的大小一定会越来越大,超过 2m 的主包以后微信开发工具就无法使用预览的功能,为了提前做好准备在一开始就进行分包处理,主包只包含公共组件和公共代码,分包里放入业务代码和业务代码
```js
//app.config.ts
export default {
pages: ['pages/index/index'],
window: {
backgroundColor: '#fff',
backgroundTextStyle: 'light',
navigationBarBackgroundColor: '#fff',
navigationBarTitleText: 'WeChat',
navigationBarTextStyle: 'black',
},
subpackages: [
{
root: 'pages/featureA',
pages: ['index/index'],
},
],
}
```data:image/s3,"s3://crabby-images/cb1b0/cb1b0ae5d8f97dda16204c500b38f54fc46964a4" alt=""
更多优化
data:image/s3,"s3://crabby-images/4bfa9/4bfa9468846a5ea8f4889825f23cf0824595b229" alt=""
## ~~使用 script setup 语法在 Taro3 实现小程序[页面生命周期方法](https://taro-docs.jd.com/taro/docs/vue-page)~~ 替换使用 Taro 3.4.0 新特性
~~使用 hooks 来封装~~
```ts
import { value getCurrentInstance } from '@tarojs/taro'
import { value onMounted } from 'vue'const Current = getCurrentInstance()
export function useDidShow(callback) {
onMounted(callback)
Current?.page?.onShow && (Current.page.onShow = callback)
}
export function usePullDownRefresh(callback) {
Current?.page?.onPullDownRefresh && (Current.page.onPullDownRefresh = callback)
}
export function useReachBottom(callback) {
Current?.page?.onReachBottom && (Current.page.onReachBottom = callback)
}
```data:image/s3,"s3://crabby-images/9fd08/9fd080e8ad129c833fea4f2d3bc52b20c4f85101" alt=""
## ~~Vuex 安装使用~~
```js
yarn add vuex@next --save
```创建 store 目录 添加 index.ts 文件
> 实现 vuex Ts 的提示 并进行模块化处理
```ts
import { value createStore, value Store } from 'vuex'
import { value InjectionKey } from 'vue'interface User {
number: number[]
}
export interface State {
user: User
}
export const key: InjectionKey<Store<State>> = Symbol()const user = {
state: {
number: [1, 2, 3],
},
mutations: {
ADD_NUMBER(state: User, payload) {
state.number.push(payload)
},
},
actions: {
addNumber(context, number) {
context.commit('ADD_NUMBER', number)
},
},
getters: {
getNumbers(state) {
return state.numbers
},
},
}const store = createStore({
modules: {
user,
},
})export default store
```## 安装 [Pinia](https://pinia.esm.dev/) 进行状态管理
````shell
yarn add pinia
yarn add taro-plugin-pinia```项目配置文件 config/index.js 中配置:
```js
// ...
plugins: ['taro-plugin-pinia']
// ...
````## taro3 配合 Vue DevTools 调试
data:image/s3,"s3://crabby-images/389b4/389b4dcafa87566373f1e79b154109320d1f3f70" alt=""
> 开启 Vue DevTools 之后 预览主包体积会大于 2M 导致无法预览 视情况开启调试 正式构建不会开启 Vue DevTools 调试
data:image/s3,"s3://crabby-images/6d3c8/6d3c8d1ae2059bd6e9480944c267935592cc08c2" alt=""
默认不开启 devtools 调试 新增 script 开启
```bash
"devtools:weapp": "npm run build:weapp -- --watch --devtools"
```## 样式封装
### 公共样式
```scss
page {
font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, Segoe UI, Arial, Roboto,
'PingFang SC', 'miui', 'Hiragino Sans GB', 'Microsoft Yahei', sans-serif;
}// 解决iPhone x 以后的机型 底部安全区域的问题 https://jelly.jd.com/article/6006b1055b6c6a01506c87fd
.safe-area-bottom {
padding-bottom: constant(safe-area-inset-bottom);
padding-bottom: env(safe-area-inset-bottom);
}
```### 1px 问题
### 超行省略
## 细节调整
### 小程序配置细节
需要注意开发者工具的项目设置:
- 需要设置关闭 ES6 转 ES5 功能,开启可能报错
- 需要设置关闭上传代码时样式自动补全,开启可能报错
- 需要设置关闭代码压缩上传,开启可能报错### 其他限制
- 小程序中不支持 `<style scoped>`,建议使用 cssModules 代替。
- 不能在页面组件的 DOM 树之外插入元素,因此不支持 `<teleport>`
- Vue 3 内部实现使用了 Proxy ,在 iOS 9 及以下操作系统无法运行。但 Vue 官方团队在正式版发布后会推出兼容版本。
- 在 H5 端使用 ref 获取基础组件的 DOM 节点,现在只能得到适配层的 Vue 组件实例,而不是对应的 webComponent 根节点。在 Vue2 里可以通过修改父元素的 refs 属性实现,但 Vue3 中组件间初始化顺序有变化,因此暂时不能支持。
- 小程序端非类似 HTML 表单标签规范的表单组件,如 Picker,暂不兼容 v-model。Vue3 的 v-model 绑定属性改为了 modelValue,事件绑定改为了 update:modelValue。对于 HTML 表单标签会自动对接表单的值与事件,例如 input 会自动对应 modelValue 与 value、update:modelValue 与 @input。但对于 Picker 这种小程序特有表单则无法对应,建议这种情况不使用 v-model。
- VirtualList 组件需要实现一份 Vue3 版本(待实现)
- 所有组件的 id 必须在整个应用中保持唯一(即使他们在不同的页面),否则可能导致事件不触发的问题