uniapp cli创建 vue3 + typeScript项目 配置eslint prettier husky

1 命令创建项目

复制代码
npx degit dcloudio/uni-preset-vue#vite-ts my-vue3-project

2 下载依赖

复制代码
npm install

3 填写appid

4 运行项目并且微信开发工具打开

复制代码
npm run dev:mp-weixin

5 安装 vscode 插件

复制代码
安装 **Vue Language Features (Volar)** :Vue3 语法提示插件
安装 **TypeScript Vue Plugin (Volar)** :Vue3+TS 插件

工作区禁用** Vue2 的 Vetur 插件(Vue3 插件和 Vue2 冲突)
作区禁用** @builtin typescript 插件(禁用后开启 Vue3 的 TS 托管模式)

uni-create-view :快速创建 uni-app 页面
uni-helper uni-app :代码提示
uniapp 小程序扩展 :鼠标悬停查文档

6 TS 类型校验

6.1 安装

复制代码
pnpm i -D miniprogram-api-typings @uni-helper/uni-app-types

6.2 tsconfig.js配置

7 代码统一风格

7.1 安装 eslint + prettier

复制代码
npm i -D eslint prettier eslint-plugin-vue @vue/eslint-config-prettier @vue/eslint-config-typescript @rushstack/eslint-patch @vue/tsconfig

7.2 新建 .eslintrc.cjs 文件,添加以下 eslint 配置

复制代码
/* eslint-env node */
require('@rushstack/eslint-patch/modern-module-resolution')

module.exports = {
  root: true,
  extends: [
    'plugin:vue/vue3-essential',
    'eslint:recommended',
    '@vue/eslint-config-typescript',
    '@vue/eslint-config-prettier',
  ],
  // 小程序全局变量
  globals: {
    uni: true,
    wx: true,
    WechatMiniprogram: true,
    getCurrentPages: true,
    getApp: true,
    UniApp: true,
    UniHelper: true,
    App: true,
    Page: true,
    Component: true,
    AnyObject: true,
  },
  parserOptions: {
    ecmaVersion: 'latest',
  },
  rules: {
    'prettier/prettier': [
      'warn',
      {
        singleQuote: true,
        semi: false,
        printWidth: 100,
        trailingComma: 'all',
        endOfLine: 'auto',
      },
    ],
    'vue/multi-word-component-names': ['off'],
    'vue/no-setup-props-destructure': ['off'],
    'vue/no-deprecated-html-element-is': ['off'],
    '@typescript-eslint/no-unused-vars': ['off'],
  },
}

7.3 配置 package.json

复制代码
{
  "script": {
    // ... 省略 ...
    "lint": "eslint . --ext .vue,.js,.ts --fix --ignore-path .gitignore"
  }
}

7.4 自动格式化代码

复制代码
npm run lint

8 GIT 工作规范流程

8.1初始化git

复制代码
git init

8.2 安装并初始化 husky 会生成 .husky 文件

复制代码
npx husky-init

8.3 安装 lint-staged

复制代码
npm i -D lint-staged

8.4 配置 package.json

复制代码
{
  "script": {
    // ... 省略 ...
  },
  "lint-staged": {
    "*.{vue,ts,js}": ["eslint --fix"]
  }
}

8.5 修改 .husky/pre-commit 文件

复制代码
#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"

npm run lint-staged
相关推荐
苏州第一深情18 分钟前
【vue+leaflet】常用的系统方法属性及常见问题(四)
前端·javascript·vue.js
Mintopia1 小时前
Node.js 中 crypto 模块的实用指南与应用示例
前端·javascript·node.js
pink大呲花1 小时前
Vue.js 中 v-model 的使用及其原理
前端·javascript·vue.js
打野赵怀真1 小时前
第 114 题:找出字符串中连续出现最多的字符和个数
前端·javascript
xll_0071 小时前
VUE3+TS+elementplus+Django+MySQL实现从前端增加数据存入数据库,并显示在前端界面上
前端·python·mysql·typescript·django·vue
uhakadotcom1 小时前
刚刚发布的next.js 15.3提供了什么新能力,怎么用?
前端·javascript·面试
bysking1 小时前
【26-请求缓存】js实现一个请求缓存的功能-bysking
前端·javascript
小钰能吃三碗饭1 小时前
第四篇:【React 开发进化论】现代状态管理方案全面详解
前端·javascript·react.js
black方块cxy1 小时前
layui 弹窗-调整窗口的缩放拖拽几次就看不到标题、被遮挡了怎么解决
前端·javascript·layui
爱的叹息1 小时前
Element Plus 图标使用方式整理
前端·javascript·vue.js