手把手教你搭建规范的团队vue项目,包含commitlint,eslint,prettier,husky,commitizen等等
1,前言
本文主要分享一个项目的规范约束从0到1的流程,从通过vue-cli创建项目,到团队协作插件安装(husky、eslint、commitlint、prettier等)。
- 本文vue-cli脚手架为5.x
- 本文webpack版本为5.x
- 本文vue版本为3.x
2,创建项目
如果你的vue-cli不是5.x版本,并且不知道怎么创建vue-cli项目,请先查看该文章:传送门
首先进入一个空间足够的磁盘,比如楼主是进的L盘,输入以下命令:
vue create demo
创建完毕后,项目结构如下图:
此时可以打开package.json
,查看项目当前装的依赖。默认是已经安装了eslint
、babel
和vue
"dependencies": {
"core-js": "^3.8.3",
"vue": "^3.2.13"
},
"devDependencies": {
"@babel/core": "^7.12.16",
"@babel/eslint-parser": "^7.12.16",
"@vue/cli-plugin-babel": "~5.0.0",
"@vue/cli-plugin-eslint": "~5.0.0",
"@vue/cli-service": "~5.0.0",
"eslint": "^7.32.0",
"eslint-plugin-vue": "^8.0.3"
}
2,安装vue全家桶
先安装一些常用的vue生态,包括axios
,vue-router
,vuex
,qs
,element-plus
等,具体使用可看下方教程链接:
npm install axios vue-router vuex qs element-plus --save
再安装typescript
npm install typescript@4.7 --save -D
3,配置prettier
首先在根目录创建
.prettierrc.js
文件,这个文件是项目的prettier
规则,内容如下:module.exports = {
tabWidth: 2, // tab缩进大小,默认为2
useTabs: false, // 使用tab缩进,默认false
semi: false, // 使用分号, 默认true
singleQuote: true, // 使用单引号, 默认false(在jsx中配置无效, 默认都是双引号)
jsxBracketSameLine: false, // 在jsx中把'>' 是否单独放一行
jsxSingleQuote: false, // 在jsx中使用单引号代替双引号
proseWrap: 'preserve', // "always" - 当超出print width(上面有这个参数)时就折行 "never" - 不折行 "perserve" - 按照文件原样折行
trailingComma: 'none', // 对象最后一项默认格式化会加逗号
arrowParens: 'avoid', // 箭头函数参数括号 默认avoid 可选 avoid(能省略括号的时候就省略)| always(总是有括号)
bracketSpacing: true, // 对象中的空格 默认true{ foo: bar } false:{foo: bar}
printWidth: 100 // 一行多长,超过的会换行
}
然后在根目录创建
.prettierignore
文件,这个是设置有那些文件需要忽略eslint
的检查,内容如下:node_modules
dist
public
.vscode
安装
prettier
的扩展。eslint-plugin-prettier
,eslint-config-prettier
npm install eslint-config-prettier eslint-plugin-prettier --save -D
4,配置eslint
首先在根目录创建
.eslintrc.js
,这个文件是项目的eslint
规则,内容如下:module.exports = {
root: true,
env: {
browser: true,
node: true,
commonjs: true,
es6: true,
amd: true,
},
globals: { // 允许的全局变量
TAny: true,
TAnyType: true,
TAnyArray: true,
TAnyFunc: true,
TDictArray: true,
TDictObject: true
},
extends: ['plugin:vue/vue3-essential', 'airbnb-base', '@vue/typescript/recommended'], // 扩展插件
parserOptions: {
ecmaVersion: 2020,
sourceType: 'module',
parser: '@typescript-eslint/parser',
ecmaFeatures: {
tsx: true, // 允许解析TSX
jsx: true,
}
},
settings: {
'import/resolver': {
node: { extensions: ['.js', '.jsx', '.ts', '.tsx', 'vue'] }
}
},
plugins: ['prettier'],
rules: {
// 0表示不不处理,1表示警告,2表示错误并退出
'vue/multi-word-component-names': 'off', // 要求组件名称始终为多字
'@typescript-eslint/no-unused-vars': [
'error',
{ varsIgnorePattern: '.*', args: 'none' }
],
camelcase: 1, // 驼峰命名
'prettier/prettier': 0, // 会优先采用prettierrc.json的配置,不符合规则会提示错误
'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
'comma-dangle': 'off',
'import/prefer-default-export': 'off', // 优先export default导出
'no-param-reassign': 'off', // 函数参数属性的赋值
semi: 'off',
'@typescript-eslint/no-explicit-any': 'warn',
'no-unused-expressions': 'off', // 联式调用使用?
'import/no-cycle': 'off', // 导入循环引用报错
'arrow-parens': 'off', // 箭头函数一个参数可以不要括号
'no-underscore-dangle': 'off', // 无下划线
'no-plusplus': 'off', // 使用一元运算符
'object-curly-newline': 'off',
'no-restricted-syntax': 'off', // 使用for of
'operator-linebreak': 'off', // after
'arrow-body-style': 'off',
'@typescript-eslint/explicit-module-boundary-types': 'off', // ts每个函数都要显式声明返回值
// 暂时屏蔽检测@别名
'import/no-useless-path-segments': 'off',
'import/no-unresolved': 'off',
'import/extensions': 'off',
'import/no-absolute-path': 'off',
'import/no-extraneous-dependencies': 'off',
'newline-per-chained-call': ['error', { ignoreChainWithDepth: 10 }],
'linebreak-style': [0, 'error', 'windows'],
'no-shadow': 'off', // 注意你必须禁用基本规则,因为它可以报告不正确的错误
'@typescript-eslint/no-shadow': ['error'],
'@typescript-eslint/member-delimiter-style': [
'error',
{
multiline: {
delimiter: 'none',
requireLast: true,
},
singleline: {
delimiter: 'semi',
requireLast: false,
},
},
],
'keyword-spacing': [
2,
{
before: true,
after: true,
},
]
}
}
然后在根目录创建
.eslintignore
文件,这个是设置那些文件需要忽略eslint
的检查,内容如下:node_modules
dist
.vscode
安装
eslint
的扩展。eslint-config-airbnb-base
,@typescript-eslint/eslint-plugin
,@vue/eslint-config-typescript
,@typescript-eslint/parser
,@vue/eslint-config-typescript
,eslint-plugin-import
。npm install eslint-config-airbnb-base @typescript-eslint/eslint-plugin @vue/eslint-config-typescript @typescript-eslint/parser @vue/eslint-config-typescript eslint-plugin-import --save -D
到这一步,就可以在package.json
文件里的scripts
对象里添加一行自动修复文件的命令 lint-fix
:
"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"lint-fix": "vue-cli-service lint --fix ./src --ext .vue,.js,.ts"
}
在项目根目录打开终端,输入npm run lint-fix
,会按照你的eslint
要求自动进行修复,部分修复不了的需要手动修改。
5,配置husky + git钩子
husky
是一个让配置git
钩子变得更简单的工具,支持所有的git
钩子。它可以将git
内置的钩子暴露出来,很方便地进行钩子命令注入,而不需要在.git/hooks
目录下自己写shell
脚本了。您可以使用它来lint
您的提交消息、运行测试、lint
代码等。当你commit
或push
的时候。husky
触发所有git
钩子脚本。
安装
husky
npm install husky --save -D
启用
husky
,启用后,根目录会出现一个.husky
的文件夹npx husky install
编辑
package.json
文件,在scripts
中添加"prepare": "husky install"
命令"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"lint-fix": "vue-cli-service lint --fix ./src --ext .vue,.js,.ts",
"prepare": "husky install"
},
在
.husky
文件夹中,新建pre-commit
文件,写入以下代码:#!/bin/sh
. "$(dirname "$0")/_/husky.sh" npx lint-staged --allow-empty
安装
lint-staged
,这是本地暂存代码的检查工具,当你git
提交代码时,会自动检查是否符合项目eslint
和prettier
规范npm install lint-staged --save -D
在项目根目录创建
.lintstagedrc.json
文件,写入以下代码:{
"*.{ts,js,vue,tsx,jsx}": ["npm run lint-fix", "prettier --write"]
}
到这一步,git
提交的时候,会自动根据项目eslint
和prettier
规范修复代码并提交,如果碰到修复不了的,会取消提交。
6,配置commitlint
在git
提交时,如果能找按照规范写好提交信息,能提高可读性以及项目维护效率,方便回溯。这里我们使用commitlint
规范git commit
提交的信息。
6.1,配置commitlint格式检查
首先安装
@commitlint/cli
和@commitlint/config-conventional
(如果要自定义提交规范,就不用安装@commitlint/config-conventional
)npm install @commitlint/cli @commitlint/config-conventional --save -D
在项目根目录的
.husky
文件夹中,新建commit-msg
文件,写入以下内容:#!/bin/sh
. "$(dirname "$0")/_/husky.sh" npx commitlint --edit $1
在项目根目录新建
commitlint.config.js
文件,写入以下内容:/*
"off"或者0:关闭规则 "warn"或1:开启规则抛出警告 "error"或2:开启规则抛出错误
*/
module.exports = {
extends: ['@commitlint/config-conventional'],
rules: {
'body-leading-blank': [2, 'always'], // body上面有换行
'footer-leading-blank': [1, 'always'], // footer上面有换行
'header-max-length': [2, 'always', 108], // header上最大108字符
'type-case': [0],
'type-empty': [0],
'scope-empty': [0],
'scope-case': [0],
'subject-full-stop': [0, 'never'],
'subject-case': [0, 'never'],
'type-enum': [
2,
'always',
[
'feat', // 新增功能、页面
'fix', // 修补bug
'docs', // 修改文档、注释
'style', // 格式:不影响代码运行的变动、空格、格式化等等
'ui', // ui修改:布局、css样式等等
'hotfix', // 修复线上紧急bug
'build', // 改变构建流程,新增依赖库、工具等(例如:修改webpack)
'refactor', // 代码重构,未新增任何功能和修复任何bug
'revert', // 回滚到上一个版本
'perf', // 优化:提升性能、用户体验等
'ci', // 对CI/CD配置文件和脚本的更改
'chore', // 其他不修改src或测试文件的更改
'test', // 测试用例:包括单元测试、集成测试
'update' // 更新:普通更新
]
]
}
}
在git提交时,填写的
commit
信息格式规范如下:<type>(<scope>): <subject> // 必填
// 空一行
<body> // 必填
// 空一行
<footer> // 可忽略不填
例子:
git commit -m 'style(home.vue):修改样式 修改了home.vue的样式,添加了背景色'
6.2,安装自定义的辅助提交依赖
首先需要安装
commitizen
和commitlint-config-cz
和cz-customizable
npm install commitizen commitlint-config-cz cz-customizable --save -D
然后新建
.cz-config.js
文件,内容如下:'use strict'
module.exports = {
types: [
{ value: 'feat', name: '新增:新增功能、页面' },
{ value: 'fix', name: 'bug:修复某个bug' },
{ value: 'docs', name: '文档:修改增加文档、注释' },
{ value: 'style', name: '格式:不影响代码运行的变动、空格、格式化等等' },
{ value: 'ui', name: 'ui修改:布局、css样式等等' },
{ value: 'hotfix', name: 'bug:修复线上紧急bug' },
{ value: 'build', name: '测试:添加一个测试' },
{ value: 'refactor', name: '重构:代码重构,未新增任何功能和修复任何bug' },
{ value: 'revert', name: '回滚:代码回退到某个版本节点' },
{ value: 'perf', name: '优化:提升性能、用户体验等' },
{ value: 'ci', name: '自动化构建:对CI/CD配置文件和脚本的更改' },
{ value: 'chore', name: '其他修改:不修改src目录或测试文件的修改' },
{ value: 'test', name: '测试:包括单元测试、集成测试' },
{ value: 'update', name: '更新:普通更新' }
],
// 交互提示信息
messages: {
type: '选择一种你的提交类型:',
scope: '选择一个影响范围(可选):',
customScope: '表示此更改的范围:',
subject: '短说明:\n',
body: '长说明,使用"|"符号换行(可选):\n',
breaking: '非兼容性说明(可选):\n',
footer: '关闭的issue,例如:#31, #34(可选):\n',
confirmCommit: '确定提交说明?(yes/no)'
},
allowCustomScopes: true,
// 设置选择了那些type,才询问 breaking message
allowBreakingChanges: ['feat', 'fix', 'ui', 'hotfix', 'update', 'perf'],
subjectLimit: 100
}
然后修改
commitlint.config.js
文件的extends
选项,改成['cz']
module.exports = {
extends: ['cz'],
......
}
编辑
package.json
文件,在scripts
中添加"commit": "git-cz"
命令"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"lint-fix": "vue-cli-service lint --fix ./src --ext .vue,.js,.ts",
"prepare": "husky install",
"commit": "git-cz"
}
在根目录终端,运行以下命令初始化命令行的选项信息:
npx commitizen init cz-customizable --save-dev --save-exact
运行完成后,在
package.json
中会出现如下选项:"config": {
"commitizen": {
"path": "./node_modules/cz-customizable"
}
}
此时,代码提交过程就多了一个可选的规范提示,提交流程是先git add .
,提交到暂存区,然后终端运行npm run commit
,根据提示选择信息或者输入即可,最后git push
推送,如下gif图所示:
附几个我个人的项目模板:
- Vite-H5-Template
- Vite-PC-Template
- Webpack-PC-Template
- H5-V2-Template
- Uniapp-Cli-V2-Template
- Uniapp-Cli-Ts-V3-Template
- PC-V2-Template
如果看了觉得有帮助的,我是@上进的鹏多多,欢迎 点赞 关注 评论;END
PS:在本页按F12,在console中输入document.querySelectorAll('.diggit')[0].click(),有惊喜哦
公众号
往期文章
- Vue2全家桶+Element搭建的PC端在线音乐网站
- 超详细的Cookie增删改查
- 助你上手Vue3全家桶之Vue-Router4教程
- 助你上手Vue3全家桶之Vue3教程
- 助你上手Vue3全家桶之VueX4教程
- 使用nvm管理node.js版本以及更换npm淘宝镜像源
- 超详细!Vue-Router手把手教程
- 超详细!Vue的九种通信方式
- 超详细!Vuex手把手教程
个人主页
手把手教你搭建规范的团队vue项目,包含commitlint,eslint,prettier,husky,commitizen等等的更多相关文章
- 教你搭建基于typescript的vue项目
自尤大去年9月推出vue对typescript的支持后,一直想开箱尝试,对于前端sr来说,vue的顺滑加上ts的面向对象,想着就非常美好~ 终于在两个月前,找到了个机会尝试了一把vue+ts的组合. ...
- 手把手教你搭建SSH框架(Eclipse版)
原文来自公众号[C you again],若需下载完整源码,请在公众号后台回复"ssh". 本期文章详细讲解了SSH(Spring+SpringMVC+Hibernate)框架的搭 ...
- 手把手教你搭建自己的Angular组件库 - DevUI
摘要:DevUI 是一款面向企业中后台产品的开源前端解决方案,它倡导沉浸.灵活.至简的设计价值观,提倡设计者为真实的需求服务,为多数人的设计,拒绝哗众取宠.取悦眼球的设计.如果你正在开发 ToB 的工 ...
- 大数据江湖之即席查询与分析(下篇)--手把手教你搭建即席查询与分析Demo
上篇小弟分享了几个“即席查询与分析”的典型案例,引起了不少共鸣,好多小伙伴迫不及待地追问我们:说好的“手把手教你搭建即席查询与分析Demo”啥时候能出?说到就得做到,差啥不能差人品,本篇只分享技术干货 ...
- 手把手教你搭建Pytest+Allure2.X环境详细教程,生成让你一见钟情的测试报告(非常详细,非常实用)
简介 宏哥之前在做接口自动化的时候,用的测试报告是HTMLTestRunner,虽说自定义模板后能满足基本诉求,但是仍显得不够档次,高端,大气,遂想用其他优秀的report框架替换之.一次偶然的机会, ...
- 手把手教你搭建FastDFS集群(下)
手把手教你搭建FastDFS集群(下) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/u0 ...
- 手把手教你搭建FastDFS集群(中)
手把手教你搭建FastDFS集群(中) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/u0 ...
- 手把手教你搭建FastDFS集群(上)
手把手教你搭建FastDFS集群(上) 本文链接:https://blog.csdn.net/u012453843/article/details/68957209 FastDFS是一个 ...
- 手把手教你搭建 ELK 实时日志分析平台
本篇文章主要是手把手教你搭建 ELK 实时日志分析平台,那么,ELK 到底是什么呢? ELK 是三个开源项目的首字母缩写,这三个项目分别是:Elasticsearch.Logstash 和 Kiban ...
随机推荐
- docker和docker compose安装使用、入门进阶案例
一.前言 现在可谓是容器化的时代,云原生的袭来,导致go的崛起,作为一名java开发,现在慌得一批.作为知识储备,小编也是一直学关于docker的东西,还有一些持续继承jenkins. 提到docke ...
- 从局部信息推测基恩士的Removing BackGround Information算法的实现。
最近从一个朋友那里看到了一些基恩士的资料,本来是想看下那个比较有特色的浓淡补正滤波器的(因为名字叫Shading Correction Filter,翻译过来的意思有点搞笑),不过看到起相关文档的附近 ...
- robotframework之环境安装
一.安装python2.7环境,python --version查询python安装的版本 二.setuptools安装
- Python快速下载商品数据,并连接数据库,保存数据
开发环境 python 3.8 pycharm 2021.2 专业版 代码实现 发送请求 获取数据 解析数据(筛选数据) 保存数据 连接数据库 开始代码 请求数据 # 伪装 headers = { ' ...
- MongoDB 的安装和基本操作
MongoDB 的安装 使用 docker 安装 下载镜像: docker pull mongo:4.4.8(推荐,下载指定版本) docker pull mongo:latest (默认下载最新版本 ...
- arcgis中nodata设为0及其小技巧
一.arcgis中nodata设为0 两个栅格进行叠加,有时会有一部分没有数据,即用identify点击该区域,Value为NoDat a,而不是像其他非空区域一样有值. 此时注意nodata区域要赋 ...
- 洛谷P2709 小B的询问 莫队做法
题干 这个是用来学莫队的例题,洛谷详解 需要注意的一点,一定要分块!不然会慢很多(直接TLE) 其中分块只在排序的时候要用,并且是给问题右端点分块 再就是注意add与del函数里的操作,增加数量不提, ...
- 【C++】学生管理系统
[C++]学生管理系统 一道非常经典的C语言题目,用C++实现 题目如下: 输入功能:由键盘输入10个学生的学号.姓名.三科成绩,并计算出平均成绩和总成绩,然后将它存入文件stud.dat. 插入 ...
- python+tkinter 的布局
from tkinter import * win = Tk() win.title("布局") # #窗口标题 win.geometry("600x500+200+20 ...
- 绿色安装MySQL5.7版本----配置my.ini文件注意事项
前言 由于前段时间电脑重装,虽然很多软件不在C盘,但是由于很多注册表以及关联文件被删除,很多软件还需要重新配置甚至卸载重装. 使用MySQL时就遇到了这种情况,在修改配置文件无效的情况下选择了重新安装 ...