You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
// standard 规范默认错误提示:
D:\pre-commit\src\test.js:2:19: Extra semicolon.
------------------------------------------------
// 利用 snazzy 美化后的错误提示:
2:19 error Extra semicolon
✖ 1 problem
// eslint 规范错误提示
D:\fe\pre-commit\src\test.js
1:13 error Strings must use doublequote quotes
1:28 error Expected linebreaks to be 'LF' but found 'CRLF' linebreak-style
1:28 error Missing semicolon semi
2:1 error Unexpected console statement no-console
2:20 error Expected linebreaks to be 'LF' but found 'CRLF' linebreak-style
✖ 5 problems (5 errors, 0 warnings)
✖ 1 problem
最终实现效果:
用 git commit 提交代码之前,利用 pre-commit git 钩子,实现代码规范检测(eslint、standard 规范),符合规范之后才可以提交到 git 仓库。这样在团队合作开发时,可以统一代码风格,如果某些同志代码不符合规范,是无法进行提交代码的。
demo地址
规范doc:
standard规范
eslint规范
git 钩子
那么问题来了,这种验证是如何实现的呢?!
请确保已经安装了: node | npm | git
安装传送门:node | npm | git
先说一下我的目录结构:
一、步骤如下(下面是 standard 规范验证):
注::point_right: 检测 src 目录下的所有文件后缀为 .js || .vue || .wpy 的文件编码,是否符合规范。
若不符合,git 钩子将会阻止 git 继续 commit, 并且会报出错误信息;
若符合代码规范,git commit 就会成功提交到本地仓库 👈
当然你可以绕过代码检测强制提交:
standard 规范错误提示如下:
二、步骤如下(下面是 eslint 规范验证):
注::point_right: eslint 自定义代码规范详情 传送门;.eslintrc.js配置详解传送门 👈
当然你可以绕过代码检测强制提交:
eslint 规范错误提示如下:
按照相应的错提示,更改代码,符合规范后,即可提交到 git 仓库。
💯 进阶
⚡ 问题:
无论修改了多少代码,每次提交代码,,检测代码总是检测指定目录下所有的文件。这样就有点尴尬了,这样检测时间比较长,造成资源浪费。如何解决呢?!
☀️ 解决:
可以结合开源库 lint-staged 做相应的修改,这个库就能保证每次检测修改的文件。
欢迎 star ⭐ ⭐ ⭐ ⭐ ⭐
The text was updated successfully, but these errors were encountered: