为何要用这些:前端
eslintnode
eslint 配合 gitreact
editorconfigwebpack
首先安装eslintnpm i eslint
由于create-react-app默认已经安装了git
"babel-eslint": "7.2.3", "eslint": "4.10.0", "eslint-config-react-app": "^2.1.0", "eslint-loader": "1.9.0", "eslint-plugin-flowtype": "2.39.1", "eslint-plugin-import": "2.8.0", "eslint-plugin-jsx-a11y": "5.1.1", "eslint-plugin-react": "7.4.0",
咱们针对咱们想要的自定义配置,咱们再安装以下es6
npm i babel-eslint \ \ eslint-config-airbnb eslint-config-standard \ \ eslint-loader \ \ eslint-plugin-import \ \ eslint-plugin-jsx-a11y \ \ eslint-plugin-node \ \ eslint-plugin-promise \ \ eslint-plugin-react \ \ eslint-plugin-standard -D
咱们在根目录下新建 .eslintrc 文件针对整个项目作一个标准的规范web
{ "extends": "standard" }
主要项目是前端工程,因此咱们在前端文件夹下新建 .eslintrc 文件,在这里去规范客户端代码,客户端代码使用 jsx,不少规则和 nodejs 是不一样的,在这里使用更加严格的规范来要求客户端代码。npm
配置的value对应的值: 0 : off 1 : warning 2 : error
{ "parser": "babel-eslint", "env": { "browser": true, "es6": true, "node": true }, "parserOptions": { "ecmaVersion": 6, "sourceType": "module" }, "extends": "airbnb", "rules": { "semi": [0], "react/jsx-filename-extension": [0], "jsx-a11y/anchor-is-valid": [0] } }
使用 babel-eslint 去解析代码,定义环境是浏览器和es6,会包含公共变量,webpack因此须要node一些环境变量,parserOptions定义版本,jsmodule模式方法书写。json
由于须要在每次编译以前都要去检查一下代码,因此还须要配置 webpack,这是create-react-app默认的promise
{ test: /\.(js|jsx|mjs)$/, enforce: 'pre', use: [ { options: { formatter: eslintFormatter, eslintPath: require.resolve('eslint'), }, loader: require.resolve('eslint-loader'), }, ], include: paths.appSrc, },
咱们但愿屏蔽掉 node_modules 文件夹下的代码
exclude:[path.resolve(__dirname, '../node_modules')]
在项目根目录下新建文件 .editorconfig webstom默认就有配置
eslint 不检测这行代码// eslint-disable-line
eslint 不检测这个文件,在开头/* eslint-disable */
在文件结尾/* eslint-enable */
安装 npm i husky -D
而后在 package.json scripts中增长git 钩子,会在执行git commit以前会调用这个命令
"lint": "eslint --ext .js --ext .jsx src/", "precommit": "npm run lint"
git commit 强制执行 eslint 经过的代码