在vue项目中配置eslint + lint-staged + prettier

在现有的vue项目中加入代码规范检查主要步骤如下:

项目改造

1、项目中可以先执行 npx eslint --fix看项目是否能正常运行

如果不报错可以略过此步骤,直接执行下面第二步。

如果报错为:

js 复制代码
ERROR TypeError: CLIEngine is not a constructor  
TypeError: CLIEngine is not a constructor

原因是eslint使用的版本过高,可执行下面命令重新更新依赖版本。同时把prettier、lint-staged这两个库也安装上。

js 复制代码
npm uninstall eslint

npm install eslint@7.32.0 -D

npm install lint-staged -D

npm i prettier -D

2、项目根目录是否存在.eslintrc

eslintrc查找规则:.eslintrc.js>.eslintrc.json>.eslintrc>package.json

3、项目根目录是否存在.prettierrc,如果存在需要和eslint中的配置相同(下面prettier --write会使用到这里的配置)

关于prettier相关配置字段可以参考官网传送门

.prettierrc文件内容可以参考下面配置:

json 复制代码
{

    "eslintIntegration": true,

    "stylelintIntegration": true,

    "tabWidth": 4,

    "semi": true,    

    "printWidth": 200,

    "singleQuote": true,

    "bracketSpacing": true,

    "arrowParens": "avoid",

    "trailingComma": "none"

}

4、修改package.json, 增加如下配置

json 复制代码
"devDependencies": {

    ... 略

    "lint-staged": "^10.2.0",

    "prettier": "^2.8.8"

    ... 略

  }

下面这段配置加在与devDependencies同级下面即可。

json 复制代码
"gitHooks": {

    "pre-commit": "lint-staged  --allow-empty"

  },

  "lint-staged": {

    "src/**/*.{js,jsx,ts,tsx,json,less,scss,css,vue}": [

      "prettier --write",

      "eslint --fix",

      "git add ."

    ]

  }

其中[js|ts]中没有引入prettier --write,每个项目可以单独加,前提eslint、prettierrc配置需要一样,否则造成冲突,可能会导致提交不通过。

5、测试代码是否生效

提交git commit 后,出现如下内容,即为生效:

6、需要注意的问题

  1. 为了避免提交时报错,先检查先项目安装的eslint版本,如果版本高于8.x.x, 最好先降低版本到7.32.0。 当然, 这取决于你本地项目的node版本,因为我参与的项目80%node版本都是14.x.x以下的,所以一般与eslint的7.32.0版本进行匹配。
  2. 团队内部分项目依赖的三方库都放在CDN上面了,所以本地可能没有vue这个库的依赖,所以需要单独安装另外一个库yorkie。执行下面命令进行安装:
js 复制代码
npm install yorkie@2.0.0 --save-dev

gitHooks 可以在package.json中使用因为vue-cli内置了yorkie , 它是一个fork自husky的一个模块。 具体可以参考文档yorkie

上面改造的步骤,可能无法覆盖所有场景,欢迎小伙伴指正纠错,感谢~。

相关推荐
老前端的功夫13 分钟前
TypeScript 类型守卫:从编译原理到高级模式
前端·javascript·架构·typescript
未来之窗软件服务24 分钟前
幽冥大陆(七十二) 东方仙盟-在线IP归属地自己封装—东方仙盟练气期
前端·javascript·tcp/ip·仙盟创梦ide·东方仙盟·阿雪技术观
QT 小鲜肉38 分钟前
【Linux命令大全】001.文件管理之mc命令(实操篇)
linux·运维·服务器·前端·笔记
土豆_potato1 小时前
AI深度思考到底开不开
前端·aigc
ohyeah1 小时前
React 中的跨层级通信:使用 Context 实现主题切换功能
前端·react.js
winfredzhang1 小时前
打造专属桌面时钟:纯HTML实现的全功能动态时钟
前端·html·农历·生肖·周次
哥本哈士奇1 小时前
使用Gradio构建AI前端 - RAG的QA模块
前端·人工智能·状态模式
扶我起来还能学_1 小时前
Vue3 proxy 数据响应式的简单实现
前端·javascript·vue
Dragon Wu2 小时前
前端项目架构 项目格式化规范篇
前端·javascript·react.js·前端框架
QQ 31316378902 小时前
文华财经软件指标公式期货买卖信号提示软件
java·前端·javascript