ESLint 通过规则(rules)来描述具体的检查行为,每条规则代表一项代码格式规范。

示例:

我们可以来看下面这条规则:

{"semi": 2,"semi": [2, 'always', {"omitLastInOneLineBlock": true}],
}

其中"semi" 是这条规则的名称,表示是否应该在行尾使用分号。“semi” 对应的值可以是一个值或者一个数组:

  • 如果为值,在该值为这条规则的错误级别,其他选项为默认。
  • 如果为数组,数组中各项都有特定含义,如:数组第一项为该规则的错误级别(level),数组的其他项为该规则 配置选项(options)。

注释规则

我们可以在文件中使用如下所示的块注释,来临时禁止规则出现警告。

/* eslint-disable */alert('xkd');/* eslint-enable */

如果要在整个文件范围内禁止规则出现警告,只需将将 /* eslint-disable */ 块注释放在文件顶部即可:

/* eslint-disable */alert('xkd');

也对指定的规则启动或禁用警告,如下所示:

/* eslint-disable no-console */var a = 1;
console.log(a);/* eslint-enable no-console */

使用行注释或块注释,在某一特定的行上禁用某个指定的规则:

alert('xkd'); // eslint-disable-line no-alertalert('xkd'); /* eslint-disable-line no-alert */

使用行注释或块注释,在某个特定的行上禁用多个规则:

alert('xkd'); // eslint-disable-line no-alert, quotes, semi// eslint-disable-next-line no-alert, quotes, semi
alert('xkd');alert('xkd'); /* eslint-disable-line no-alert, quotes, semi *//* eslint-disable-next-line no-alert, quotes, semi */
alert('xkd');

错误级别

规则的错误级别分为三级:

  • 0 或者"off" ,表示关闭规则。
  • 1或者"warn" ,打开规则,并且将规则视为一个警告(并不会导致检查不通过)。
  • 2或者"error" ,打开规则,并且将规则视为一个错误 (退出码为1,检查不通过)。

常用规则

与 JavaScript 代码中可能的错误或逻辑错误有关的规则:

no-cond-assign       // 禁止条件表达式中出现模棱两可的赋值操作符
no-console              // 禁用console
no-constant-condition   // 禁止在条件中使用常量表达式
no-debugger             // 禁用 debugger
no-dupe-args            // 禁止 function 定义中出现重名参数
no-dupe-keys            // 禁止对象字面量中出现重复的 key
no-duplicate-case       // 禁止出现重复的 case 标签
no-empty                // 禁止出现空语句块
no-ex-assign            // 禁止对 catch 子句的参数重新赋值
no-extra-boolean-cast   // 禁止不必要的布尔转换
no-extra-parens         // 禁止不必要的括号
no-extra-semi           // 禁止不必要的分号
no-func-assign          // 禁止对 function 声明重新赋值
no-inner-declarations   // 禁止在嵌套的块中出现变量声明或 function 声明
no-irregular-whitespace // 禁止在字符串和注释之外不规则的空白
no-obj-calls            // 禁止把全局对象作为函数调用
no-sparse-arrays        // 禁用稀疏数组
no-prototype-builtins   // 禁止直接使用Object.prototypes 的内置属性
no-unexpected-multiline // 禁止出现令人困惑的多行表达式
no-unreachable          // 禁止在return、throw、continue 和 break语句之后出现不可达代码
use-isnan               // 要求使用 isNaN() 检查 NaN
valid-typeof            // 强制 typeof 表达式与有效的字符串进行比较

下面这些规则是关于最佳实践的,帮助你避免一些问题:

array-callback-return   // 强制数组方法的回调函数中有 return 语句
block-scoped-var        // 强制把变量的使用限制在其定义的作用域范围内
complexity              // 指定程序中允许的最大环路复杂度
consistent-return       // 要求 return 语句要么总是指定返回的值,要么不指定
curly                   // 强制所有控制语句使用一致的括号风格
default-case            // 要求 switch 语句中有 default 分支
dot-location            // 强制在点号之前和之后一致的换行
dot-notation            // 强制在任何允许的时候使用点号
eqeqeq                  // 要求使用 === 和 !==
guard-for-in            // 要求 for-in 循环中有一个 if 语句
no-alert                // 禁用 alert、confirm 和 prompt
no-case-declarations    // 不允许在 case 子句中使用词法声明
no-else-return          // 禁止 if 语句中有 return 之后有 else
no-empty-function       // 禁止出现空函数
no-eq-null              // 禁止在没有类型检查操作符的情况下与 null 进行比较
no-eval                 // 禁用 eval()
no-extra-bind           // 禁止不必要的 .bind() 调用
no-fallthrough          // 禁止 case 语句落空
no-floating-decimal     // 禁止数字字面量中使用前导和末尾小数点
no-implicit-coercion    // 禁止使用短符号进行类型转换
no-implicit-globals     // 禁止在全局范围内使用 var 和命名的 function 声明
no-invalid-this         // 禁止 this 关键字出现在类和类对象之外
no-lone-blocks          // 禁用不必要的嵌套块
no-loop-func            // 禁止在循环中出现 function 声明和表达式
no-magic-numbers        // 禁用魔术数字
no-multi-spaces         // 禁止使用多个空格
no-multi-str            // 禁止使用多行字符串
no-new                  // 禁止在非赋值或条件语句中使用 new 操作符
no-new-func             // 禁止对 Function 对象使用 new 操作符
no-new-wrappers         // 禁止对 String,Number 和 Boolean 使用 new 操作符
no-param-reassign       // 不允许对 function 的参数进行重新赋值
no-redeclare            // 禁止使用 var 多次声明同一变量
no-return-assign        // 禁止在 return 语句中使用赋值语句
no-script-url           // 禁止使用 javascript: url
no-self-assign          // 禁止自我赋值
no-self-compare         // 禁止自身比较
no-sequences            // 禁用逗号操作符
no-unmodified-loop-condition   // 禁用一成不变的循环条件
no-unused-expressions   // 禁止出现未使用过的表达式
no-useless-call         // 禁止不必要的 .call() 和 .apply()
no-useless-concat       // 禁止不必要的字符串字面量或模板字面量的连接
vars-on-top             // 要求所有的 var 声明出现在它们所在的作用域顶部

与使用严格模式和严格模式指令有关规则:

strict  // 要求或禁止使用严格模式指令

与变量声明有关规则:

init-declarations     // 要求或禁止 var 声明中的初始化
no-catch-shadow       // 不允许 catch 子句的参数与外层作用域中的变量同名
no-restricted-globals // 禁用特定的全局变量
no-shadow             // 禁止 var 声明 与外层作用域的变量同名
no-undef              // 禁用未声明的变量,除非它们在 /global / 注释中被提到
no-undef-init         // 禁止将变量初始化为 undefined
no-unused-vars        // 禁止出现未使用过的变量
no-use-before-define  // 不允许在变量定义之前使用它们

关于Node.js 或 在浏览器中使用CommonJS 的规则:

global-require        // 要求 require() 出现在顶层模块作用域中
handle-callback-err   // 要求回调函数中有容错处理
no-mixed-requires     // 禁止混合常规 var 声明和 require 调用
no-new-require        // 禁止调用 require 时使用 new 操作符
no-path-concat        // 禁止对 dirname 和 filename进行字符串连接
no-restricted-modules // 禁用指定的通过 require 加载的模块

下面的规则是关于风格指南的,而且是非常主观的

array-bracket-spacing            // 强制数组方括号中使用一致的空格
block-spacing                   // 强制在单行代码块中使用一致的空格
brace-style                     // 强制在代码块中使用一致的大括号风格
camelcase                       // 强制使用骆驼拼写法命名约定
comma-spacing                   // 强制在逗号前后使用一致的空格
comma-style                     // 强制使用一致的逗号风格
computed-property-spacing       // 强制在计算的属性的方括号中使用一致的空格
eol-last                        // 强制文件末尾至少保留一行空行
func-names                      // 强制使用命名的 function 表达式
func-style                      // 强制一致地使用函数声明或函数表达式
indent                          // 强制使用一致的缩进
jsx-quotes                      // 强制在 JSX 属性中一致地使用双引号或单引号
key-spacing                     // 强制在对象字面量的属性中键和值之间使用一致的间距
keyword-spacing                 // 强制在关键字前后使用一致的空格
linebreak-style                 // 强制使用一致的换行风格
lines-around-comment            // 要求在注释周围有空行
max-depth                       // 强制可嵌套的块的最大深度
max-len                         // 强制一行的最大长度
max-lines                       // 强制最大行数
max-nested-callbacks            // 强制回调函数最大嵌套深度
max-params                      // 强制 function 定义中最多允许的参数数量
max-statements                  // 强制 function 块最多允许的的语句数量
max-statements-per-line         // 强制每一行中所允许的最大语句数量
new-cap                         // 要求构造函数首字母大写
new-parens                      // 要求调用无参构造函数时有圆括号
newline-after-var               // 要求或禁止 var 声明语句后有一行空行
newline-before-return           // 要求 return 语句之前有一空行
newline-per-chained-call        // 要求方法链中每个调用都有一个换行符
no-array-constructor            // 禁止使用 Array 构造函数
no-continue                     // 禁用 continue 语句
no-inline-comments              // 禁止在代码行后使用内联注释
no-lonely-if                    // 禁止 if 作为唯一的语句出现在 else 语句中
no-mixed-spaces-and-tabs        // 不允许空格和 tab 混合缩进
no-multiple-empty-lines         // 不允许多个空行
no-negated-condition            // 不允许否定的表达式
no-plusplus                     // 禁止使用一元操作符 ++ 和 –
no-spaced-func                  // 禁止 function 标识符和括号之间出现空格
no-trailing-spaces              // 禁用行尾空格
no-whitespace-before-property   // 禁止属性前有空白
object-curly-newline            // 强制花括号内换行符的一致性
object-curly-spacing            // 强制在花括号中使用一致的空格
object-property-newline         // 强制将对象的属性放在不同的行上
one-var                         // 强制函数中的变量要么一起声明要么分开声明
one-var-declaration-per-line    // 要求或禁止在 var 声明周围换行
operator-assignment             // 要求或禁止在可能的情况下要求使用简化的赋值操作符
operator-linebreak              // 强制操作符使用一致的换行符
quote-props                     // 要求对象字面量属性名称用引号括起来
quotes                          // 强制使用一致的反勾号、双引号或单引号
require-jsdoc                   // 要求使用 JSDoc 注释
semi                            // 要求或禁止使用分号而不是 ASI
semi-spacing                    // 强制分号之前和之后使用一致的空格
sort-vars                       // 要求同一个声明块中的变量按顺序排列
space-before-blocks             // 强制在块之前使用一致的空格
space-before-function-paren     // 强制在 function的左括号之前使用一致的空格
space-in-parens                 // 强制在圆括号内使用一致的空格
space-infix-ops                 // 要求操作符周围有空格
space-unary-ops                 // 强制在一元操作符前后使用一致的空格
spaced-comment                  // 强制在注释中 // 或 /* 使用一致的空格

链接:https://www.9xkd.com/

ESLint 常用规则相关推荐

  1. eslint常用规则配置和解释

    rule解释 "no-alert": 0,//禁止使用alert confirm prompt "no-array-constructor": 2,//禁止使用 ...

  2. vue 配置Eslint常用的校验规则汇总

    规则的含义: "off" or 0 - 关闭(禁用)规则  "warn" or 1 - 将规则视为一个警告(并不会导致检查不通过)  "error&q ...

  3. StyleCop(C#代码规范分析工具)---2.常用规则介绍(一)

    寄菜鸟 对于像我这样还是菜鸟级的程序员来说,Leader分配给我的任务,只要按时做完就OK,哪有时间去理代码的优雅,可读性!就算有,就咱这个水平,...!别人看不懂管他呢!只要我看得懂不就行了!由于平 ...

  4. Eslint 配置 + 规则说明 - 综合引入篇

    一. 配置: 参考引用文章:https://blog.csdn.net/hsl0530hsl/article/details/78594973 二.规则说明: 参考引用文章:https://blog. ...

  5. Linux iptables 防火墙常用规则

    2019独角兽企业重金招聘Python工程师标准>>> 米扑博客 总结了 Linux iptables 防火墙常用规则,分享出来. iptables 安装 yum install i ...

  6. AD21常用规则设置

    AD中常用规则设置 打开菜单栏Design(设计)下的Rules(规则),会弹出规则设置界面 有Electrical(电气规则).Routing(走线规则).SMT(贴片规则).Mask(掩膜规则). ...

  7. centos7【防火墙】常用规则

    1.防火墙常用规则 systemctl start iptables systemctl stop iptables systemctl restart iptablesiptables -nvL 1 ...

  8. html5哪个标签首字母大写,HTML5中标签和常用规则有哪些?html5标签以及规则的介绍...

    这篇文章给大家介绍的内容是关于HTML5中标签和常用规则有哪些?html5标签以及规则的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 1. 命名规则 [强制]class:必须单 ...

  9. ElementUI的表单验证及常用规则

    element-cn.eleme.io/#/zh-CN/com- 在官网上有关于form组件的详细介绍 这里总结了几个常用的规则,方便下次使用 必填,必选,邮箱,手机号,时间,数字,数组,字符长度, ...

最新文章

  1. 【LaTeX】E喵的LaTeX新手入门教程(3)数学公式
  2. matlab adc仿真,[转载]关于ADC仿真做FFT的设置和结果分析
  3. Oracle入门(十三A1)之替换变量,变量名,变量名
  4. 【LeetCode笔记】1. 两数之和(JAVA、哈希表)
  5. live555学习笔记-RTSPClient分析
  6. window10 无法访问 Toshiba e-studio355 扫描打印一体机的机器扫描文件夹
  7. linux pae内核安装,CentOS6.9 32位 编译无 pae 内核
  8. 一刀工具箱 - 古诗文查询
  9. 网络型多媒体计算机教室功能是,多媒体网络教室中的信息技术教学
  10. border缩写属性
  11. android 传感器坐标系_android 传感器坐标
  12. 文字识别 SDK 11 给大家看一个手册
  13. 有人对你说辛苦了要怎么回复
  14. 与编程密切相关的数学——离散数学——代数系统篇
  15. 算法第一章作业(c++代码规范+数学之美读后感+规划)
  16. 原生js实现公历转农历
  17. C++11 IOC容器
  18. .bat文件不能运行怎么办? bat文件不能运行解决方法。
  19. Excel如何批量替换文本
  20. 共享单车的分配与调度

热门文章

  1. 一个房间3盏灯,门外有3个开关,进一次门怎么分清楚哪个开关开哪个灯?
  2. c语言编程过程中的常见错误,C语言编程常见错误与解决办法
  3. python爬虫,人人网登录
  4. 单片机滤波算法之一阶滤波
  5. [WC2022-DMY]我被卷飞了(stars)
  6. Java之项目用到类Objects,TreeMap排序简单分享
  7. no qualifying bean of type TransactionManager avaliable 错误
  8. 人生苦短我用python壁纸_人生苦短我用Python分分钟下载知乎美图给你看
  9. UCOSII-内存管理
  10. 无纸化会议交互系统部署