We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
本文为博客迁移过来,原文链接: 项目代码规范工作流——editor、prettier、eslint、git-check:2018-3-29
最近部门进了挺多新前端,有实习生 有应届生,人一多 代码规范就不能完全依赖 “口口相传” 去约束了, 特别是看到一堆的 有分号,无分号,四缩进,二缩进等问题
对于有小小代码洁癖的我实在是受不了 于是终于在项目中 集成各种用来 规范(约束)的工具。
主要有:
本地一些环境:node 8.9.4, npm 5.6.0, oxs 10.13.3, 编辑器 vscodeeeeee
node 8.9.4
npm 5.6.0
oxs 10.13.3
vscodeeeeee
What is EditorConfig? 官网给出的答案是:editorconfig帮助开发人员在不同的编辑器和ide之间定义和维护一致的编码风格。 简单来说就是跨编辑器使用同一份代码缩进等配置
EditorConfig 集成起来十分简单, 大概就是创建配置文件,安装相应的编辑器插件即可。
.editorconfig
我用的是 vscode 直接安装这个 EditorConfig for vs code,安装完重启,编辑器就会根据配置文件里面的配置来控制代码缩进等行为
EditorConfig for vs code
附上项目的配置文件
root = true [*] charset = utf-8 end_of_line = lf # mac linux/unix 都用lf。 window 设置 cr 在 *nix 有问题 indent_size = 4 indent_style = space max_line_length = 120 trim_trailing_whitespace = true [*.jsx] indent_size= 2
现在有了一些基本的配置,以后写的代码就可以比较规范一点点点,但是原来的旧代码怎么办呢? 不可能一个文件一个文件去打开吧,不完全统计 项目有上千个编辑的文件....一个一个去手动打开不符合程序员的风格
so... Prettier就是为我们做这些事情的
npm i --save-dev prettier
.prettierrc
editorConfig
package.json
"prettier": "prettier --write ./*"
我项目里面用的是 "prettier": "prettier --write './src/**/*.js' './src/**/*.jsx' './src/**/*.css' './src/**/*.scss'",
"prettier": "prettier --write './src/**/*.js' './src/**/*.jsx' './src/**/*.css' './src/**/*.scss'",
.prettierignore
npm run prettier
附上配置文件:
// https://prettier.io/docs/en/options.html module.exports = { trailingComma: "es5", // 数组 对象尾随逗号 [arr, ] { obj, } // bracketSpacing: true, // 对象空格 { foo: bar }, false=> {foo:bar} // jsxBracketSameLine: false, // jsx闭标签是否另起一行 <Test></Test> // arrowParens: 'avoid', // 箭头函数是否省略括号 a=> a, (a)=> a singleQuote: true, // 单引号 }
/node_modules /dist /src/lib/ /src/global/fonts
有了上面介绍的 editor、prettier还是远远不够的,因为 js语法 不是很严格,比如有没有分号啊 之类的问题还是要用 eslint 来约束的。
editor
prettier
在很多年前,我是特别反感 Eslint 的,因为经常写得一点不规范,直接就报 error 整个项目跑不起来。 但是 存在即合理,现在觉得这东西贼好用。
npm i --save-dev eslint
./node_modules/.bin/eslint --init
.eslintrc
这里可以直接选 Use a popular style guide 然后选行业比较看好的规范 airbnb的,原先是打算选这个,但是后面发现和项目现有的规范很不相同,所以后面就走回答问题选项。
Use a popular style guide
airbnb
"eslint": "eslint --fix ./"
我写的是 "eslint": "eslint --fix './src/**/*.{jsx, js}'",
"eslint": "eslint --fix './src/**/*.{jsx, js}'",
.eslintignore
开启eslint 检查
关闭vscode自带的js检查
eslint插件会智能检查编辑状态的 JS 文件,并自动修复;npm run eslint 脚本可以检查和智能修复“对应的文件”。 不过亲测修复的效果比较一般,更多的报错需要手动去处理
npm run eslint
在配置eslint的时候 遇到了几个比较郁闷的地方
比如说之前项目写的比较不规范,出现了很多类似:export default from 'file-path'的语句,但是eslint不认,觉得这是不符合规范的,需要改为 export { default } from 'file-path'
export default from 'file-path'
export { default } from 'file-path'
这点我也比较认同,但是 这么多个文件,一个一个改是不存在的,所以写了个短脚本去处理
const fs = require('fs'); const path = require('path'); function scan({dirPath}) { const isDirectory = fs.statSync(dirPath).isDirectory(); if (isDirectory) { const childs = fs.readdirSync(dirPath); childs.forEach(child=> { const nextPath = path.join(dirPath, child); const stat = fs.statSync(nextPath); const isDirectory = stat.isDirectory(); const isFile = stat.isFile(); const extname = isFile && path.extname(child); // 文件夹类型 递归 if (isDirectory) scan({dirPath: nextPath}); // 排除不是 js jsx 的文件 if (!['.js', '.jsx'].includes(extname)) return; // 开始读文件 let fileStr = fs.readFileSync(nextPath) +''; const exg = /export default from/gi; if (exg.exec(fileStr)) fileStr = fileStr.replace('export default from', 'export {default} from'); fs.writeFileSync(nextPath, fileStr, {encoding: 'utf-8'}); }); } } scan({ dirPath: path.join(process.cwd(), '/src'), });
安装对应的 eslint 处理插件: npm i --save-dev eslint-import-resolver-webpack eslint-plugin-import
npm i --save-dev eslint-import-resolver-webpack eslint-plugin-import
在 .eslint.js 里面加这段配置
.eslint.js
"settings": { 'import/resolver': { webpack: { config: getWebpackConfig, // 这里是webpack配置路径 } }, },
项目是在 浏览器运行, 又是 es6语法, 又有一些node脚本,会有一些全局的变量引用提示报错,怎么办? 改配置!
"env": { browser: true, es6: true, node: true, },
项目是后端模版渲染的,会有一些全局变量,eslint报错怎么办? 改配置!
"globals": { __DEV__: true, __HTTPS__: true, FB: true, ga: true, $: true, ercjs: true, google: true, IS_APP: true, i18n: true, Zepto: true, AdjustEvent: true, Adjust: true, fbq: true, },
项目用了很多新语法 eslint 不识别, 用了 react 怎么办? 改配置...具体的 谷歌一下 一堆答案 不再赘述
Flow可以理解为 很轻量型 无侵入的 静态类型检查 项目暂时没有考虑集成,所以这里不做过多介绍
既然我们 有了编辑器的配置, js编辑实时检查, 但是如果有些小伙伴不遵守规则 搞事情怎么办呢? 这时候我们可以在最后一个流程加上验证的部分, 在git 提交的时候跑一些脚本去验证,如果通过就给提交,不通过就提示错误
lint-staged 可以帮我们做这些事情
npm i --save-dev lint-staged husky
"precommit": "lint-staged"
这时候在git commit 之前会跑 lint-staged的东西
scripts
"lint-staged": { // 上面提供的“自动化脚本” "*.js": ["eslint --fix", "git add"], "*.json": ["prettier --write", "git add"], "*.css": ["prettier --write", "git add"], "*.scss": ["prettier --write", "git add"], "*.md": ["prettier --write", "git add"] }
因为项目是本地打包再推远程,所以我的配置是指定了 src下的 "src/**/*.js": [ "eslint --fix", "git add" ], "src/**/*.jsx": [ "eslint --fix", "git add" ], "src/**/*.css": [ "prettier --write", "git add" ], "src/**/*.scss": [ "prettier --write", "git add" ]
"src/**/*.js": [ "eslint --fix", "git add" ], "src/**/*.jsx": [ "eslint --fix", "git add" ], "src/**/*.css": [ "prettier --write", "git add" ], "src/**/*.scss": [ "prettier --write", "git add" ]
这样在提交之前就会对 新增的(git add) .js 文件执行 "eslint --fix" 脚本, 以此类推...
"eslint --fix"
emmmmmmmmmmmmmmmmmmmmmmmmm 虽然看起来挺简单的,但是整套结合项目去折腾下来 挺多坑的。 特别是eslint这块的配置
第一次跑 airbnb 的项目: 目前项目配置官方推荐的 esling 之后: 把error改为 warn保证项目能跑起来: git提交检查失败:
最后附上eslint配置
const getWebpackConfig = require('./config/webpack.dev.config')(process.cwd()); module.exports = { "parser": "babel-eslint", "extends": ['eslint:recommended', "plugin:react/recommended", "prettier"], "parserOptions": { "ecmaVersion": 8, "sourceType": "module", "ecmaFeatures": { "jsx": true, "modules": true, "experimentalObjectRestSpread": true } }, "plugins": ["react"], "settings": { 'import/resolver': { webpack: { config: getWebpackConfig, } }, "react": { "pragma": "React", "version": "16.1.1" } }, "env": { browser: true, es6: true, node: true, }, "globals": { __DEV__: true, __HTTPS__: true, FB: true, ga: true, $: true, ercjs: true, google: true, IS_APP: true, i18n: true, Zepto: true, AdjustEvent: true, Adjust: true, fbq: true, }, "rules": { "sort-imports": 0, "import/first": 0, "import/no-named-as-default": 0, "import/no-named-as-default-member": 0, "import/extensions": 0, "prefer-destructuring": 0, "no-new": 0, "react/jsx-filename-extension": 0, "no-plusplus": 0, "func-names": 0, "no-console": 0, "no-useless-escape": 0, "semi": 2, // 这些规则后面会改为错误,暂时先警告 "no-unused-vars": 1, "react/prop-types": 1, "react/no-string-refs": 1, "react/jsx-key": 1, "react/no-unescaped-entities": 1 } }
The text was updated successfully, but these errors were encountered:
No branches or pull requests
背景
最近部门进了挺多新前端,有实习生 有应届生,人一多
代码规范就不能完全依赖 “口口相传” 去约束了, 特别是看到一堆的 有分号,无分号,四缩进,二缩进等问题
对于有小小代码洁癖的我实在是受不了 于是终于在项目中 集成各种用来 规范(约束)的工具。
主要有:
本地一些环境:
node 8.9.4
,npm 5.6.0
,oxs 10.13.3
, 编辑器vscodeeeeee
EditorConfig
What is EditorConfig?
官网给出的答案是:editorconfig帮助开发人员在不同的编辑器和ide之间定义和维护一致的编码风格。
简单来说就是跨编辑器使用同一份代码缩进等配置
EditorConfig 集成起来十分简单, 大概就是创建配置文件,安装相应的编辑器插件即可。
.editorconfig
文件我用的是 vscode 直接安装这个
EditorConfig for vs code
,安装完重启,编辑器就会根据配置文件里面的配置来控制代码缩进等行为附上项目的配置文件
Prettier
现在有了一些基本的配置,以后写的代码就可以比较规范一点点点,但是原来的旧代码怎么办呢?
不可能一个文件一个文件去打开吧,不完全统计 项目有上千个编辑的文件....一个一个去手动打开不符合程序员的风格
so... Prettier就是为我们做这些事情的
npm i --save-dev prettier
.prettierrc
配置文件该配置文件会继承
editorConfig
的配置package.json
添加脚本:"prettier": "prettier --write ./*"
.prettierignore
文件,用来忽略一些文件 && 目录npm run prettier
呼呼 看到提示一千个文件更改记录 哈哈哈附上配置文件:
Eslint
有了上面介绍的
editor
、prettier
还是远远不够的,因为 js语法 不是很严格,比如有没有分号啊 之类的问题还是要用 eslint 来约束的。在很多年前,我是特别反感 Eslint 的,因为经常写得一点不规范,直接就报 error 整个项目跑不起来。
但是 存在即合理,现在觉得这东西贼好用。
npm i --save-dev eslint
./node_modules/.bin/eslint --init
配置.eslintrc
。package.json
添加脚本:"eslint": "eslint --fix ./"
.eslintignore
文件,并向其添加需要忽略的文件或目录。开启eslint 检查
关闭vscode自带的js检查
eslint插件会智能检查编辑状态的 JS 文件,并自动修复;
npm run eslint
脚本可以检查和智能修复“对应的文件”。 不过亲测修复的效果比较一般,更多的报错需要手动去处理在配置eslint的时候 遇到了几个比较郁闷的地方
可以先把一些报错项改为 警告项,慢慢迭代 免得一上eslint 要停几天来修改原来的文件
一些简单的处理可以写脚本去做
比如说之前项目写的比较不规范,出现了很多类似:
export default from 'file-path'
的语句,但是eslint不认,觉得这是不符合规范的,需要改为export { default } from 'file-path'
这点我也比较认同,但是 这么多个文件,一个一个改是不存在的,所以写了个短脚本去处理
webpack别名引用 路径报错问题
安装对应的 eslint 处理插件:
npm i --save-dev eslint-import-resolver-webpack eslint-plugin-import
在
.eslint.js
里面加这段配置其他注意问题
项目是在 浏览器运行, 又是 es6语法, 又有一些node脚本,会有一些全局的变量引用提示报错,怎么办?
改配置!
项目是后端模版渲染的,会有一些全局变量,eslint报错怎么办?
改配置!
项目用了很多新语法 eslint 不识别, 用了 react 怎么办?
改配置...具体的 谷歌一下 一堆答案 不再赘述
Flow
Flow可以理解为 很轻量型 无侵入的 静态类型检查
项目暂时没有考虑集成,所以这里不做过多介绍
git-check
既然我们 有了编辑器的配置, js编辑实时检查, 但是如果有些小伙伴不遵守规则 搞事情怎么办呢?
这时候我们可以在最后一个流程加上验证的部分, 在git 提交的时候跑一些脚本去验证,如果通过就给提交,不通过就提示错误
lint-staged 可以帮我们做这些事情
npm i --save-dev lint-staged husky
package.json
添加运行脚本"precommit": "lint-staged"
package.json
添加内容: 注意,这时候不是加在scripts
里面,而是加在同级"lint-staged": { // 上面提供的“自动化脚本” "*.js": ["eslint --fix", "git add"], "*.json": ["prettier --write", "git add"], "*.css": ["prettier --write", "git add"], "*.scss": ["prettier --write", "git add"], "*.md": ["prettier --write", "git add"] }
这样在提交之前就会对 新增的(git add) .js 文件执行
"eslint --fix"
脚本, 以此类推...End
emmmmmmmmmmmmmmmmmmmmmmmmm 虽然看起来挺简单的,但是整套结合项目去折腾下来 挺多坑的。
特别是eslint这块的配置
第一次跑data:image/s3,"s3://crabby-images/455aa/455aa2fb44bfac3a26c1810492f4ed85b0e23d82" alt="eror1"
data:image/s3,"s3://crabby-images/0a59e/0a59e97b27ea7eb7a5ad523c4f93030ad92b3423" alt="eror2"
data:image/s3,"s3://crabby-images/df1d2/df1d243ed3a2f6582da45b6555912bfb4bf5d130" alt="eror3"
data:image/s3,"s3://crabby-images/87c62/87c624e476ea99865f20710987fe6886a1845174" alt="git-check"
airbnb
的项目:目前项目配置官方推荐的 esling 之后:
把error改为 warn保证项目能跑起来:
git提交检查失败:
最后附上eslint配置
The text was updated successfully, but these errors were encountered: