使用eslint和editorconfig规范代码
为什么要用这些:
eslint
随着ECMAScript版本一直更新的Js lint工具,插件丰富,并且能够套用规范,规则非常丰富,能够满足大部分团队的需求。
eslint 配合 git
为了最大程度控制每个人的规范,我们可以在git commit代码的时候,使用git hook调用eslint进行代码规范验证,不规范的代码无法提交到仓库。
editorconfig
不同编辑器对文本的格式会有一定的区别,如果不统一一些规范,可能你和别人合作的时候每次更新下来别人的代码就会出一大堆错误-webstorm自动支持editorconfig配置文件。
首先安装eslintnpm i eslint
因为create-react-app默认已经安装了
我们针对我们想要的自定义配置,我们再安装如下
我们在根目录下新建 .eslintrc 文件针对整个项目做一个标准的规范
主要项目是前端工程,所以我们在前端文件夹下新建 .eslintrc 文件,在这里去规范客户端代码,客户端代码使用 jsx,很多规则和 nodejs 是不同的,在这里使用更加严格的规范来要求客户端代码。
配置的value对应的值: 0 : off 1 : warning 2 : error
使用 babel-eslint 去解析代码,定义环境是浏览器和es6,会包含公共变量,webpack所以需要node一些环境变量,parserOptions定义版本,jsmodule模式方法书写。
因为需要在每次编译之前都要去检查一下代码,所以还需要配置 webpack,这是create-react-app默认的
在项目根目录下新建文件 .editorconfig webstom默认就有配置
- root = true 项目根目录
- [*] 所有文件都应用这个规则
- charset = utf-8 编码模式
- indent_style = space 使用 tab 的样式制表符和 space
- indent_size = 2
- end_of_line = lf 行尾结尾方式
- insert_final_newline = true 自动保存行尾最后一行是空行
- trim_trailing_whitespace = true 一行结束后面的空格自动去掉
eslint 不检测这行代码 // eslint-disable-line
eslint 不检测这个文件,在开头 /* eslint-disable */
在文件结尾/* eslint-enable */
安装 npm i husky -D
然后在 package.json scripts中增加git 钩子,会在执行git commit之前会调用这个命令
git commit 强制执行 eslint 通过的代码
原文链接:https://www.f2er.com/js/31992.html