加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Eslint规则字典

发布时间:2020-12-17 08:27:57 所属栏目:安全 来源:网络整理
导读:Eslint(二):规则字典 字数:6190 阅读时间:30分钟 Standard规范+Angular规范集合 代码格式 indent "indent": ["error",4] 规定使用几个空格进行缩进。第二个参数表示空格的个数,默认是2个,我们这个设置的是四格。 block-spacing "block-spacing": ["erro

Eslint(二):规则字典

字数:6190

阅读时间:30分钟


Standard规范+Angular规范集合

代码格式

indent

"indent": ["error",4]

规定使用几个空格进行缩进。第二个参数表示空格的个数,默认是2个,我们这个设置的是四格。


block-spacing

"block-spacing": ["error","always"]

规定单行代码两边加空格。第二个参数有"always"、"never",默认值为"always",表示需要至少一个空格,"never"表示不需要空格。代码示例如下:

function foo () {return true}    // ? avoid
function foo () { return true }  // ? ok


brace-style

"brace-style": ["error","1tbs",{ "allowSingleLine": true }]

规定 “else” 关键字要与花括号保持在同一行。第二个参数表示不同的规则风格,可取"1tbs"、“stroustrup”、“allman”三种风格。第三个参数表示是否允许大括号在同一行,默认值为 “false”。代码示例如下:

// ? ok
if (condition) {
  // ...
} else {
  // ...
}


// ? avoid
if (condition)
{
  // ...
}
else
{
  // ...
}


comma-spacing

"comma-spacing": ["error",{ "before": false,"after": true }]

规定逗号后面必须添加空格。第二个参数用来设置逗号前和逗号后是否添加空格。代码示例如下:

// ? ok
var list = [1,2,3,4]
function greet (name,options) { ... }

// ? avoid
var list = [1,options) { ... }


curly

"curly": ["error","multi-line"]

规定多行 if 语句的的括号不能省略。第二个参数配置那些场景会报错,可取值“all”、“multi”、“multi-line”、“multi-or-nest”、“consistent”。这里“multi-line”表示多行代码不能省略。代码示例如下:

// ? ok
if (options.quiet !== true) console.log('done')

// ? ok
if (options.quiet !== true) {
  console.log('done')
}

// ? avoid
if (options.quiet !== true)
  console.log('done')


dot-location

"dot-location": ["error","property"]

规定点号操作符须与属性需在同一行。第二个参数配置点的位置,取值“property”和“object”。“property”表示点与属性同一行,“object”表示点与对象同一行。代码示例如下:

console.
    log('hello')  // ? avoid

  console
    .log('hello') // ? ok


eol-last

"eol-last": "error"

规定文件末尾空一行,以防文件解析错误。


func-call-spacing

"func-call-spacing": ["error","never"]

规定函数调用时标识符与括号间不留间隔。第二个参数取值“never”和“always”,"never"表不留空格,"always"表要留空格。代码示例如下:

console.log ('hello') // ? avoid
console.log('hello')  // ? ok


key-spacing

"key-spacing": ["error",{ "beforeColon": false,"afterColon": true }]

规定键值对中冒号与值之间要留空白。第二个参数配置前后是否留白。示例代码如下:

var obj = { 'key' : 'value' }    // ? avoid
var obj = { 'key' :'value' }     // ? avoid
var obj = { 'key':'value' }      // ? avoid
var obj = { 'key': 'value' }     // ? ok


no-mixed-spaces-and-tabs

"no-mixed-spaces-and-tabs": "error"

规定不能混合使用空格与制表符作为缩进。


no-multi-spaces

"no-multi-spaces": "error"

规定除了缩进,不要使用多个空格。代码示例如下:

const id =    1234    // ? avoid
const id = 1234       // ? ok

no-multiple-empty-lines

"no-multiple-empty-lines": ["error",{ "max": 1,"maxEOF": 0 }]

规定不允许有连续多行空行且文件头部不允许空行。第二个参数是一个对象,里面有三个属性。“max”属性表连续空行数,“maxEOF”表文件结尾空行数,“maxBOF”表示文件开头空行数。


no-trailing-spaces

"no-trailing-spaces": "error"

规定行末不留空格。


no-whitespace-before-property

"no-whitespace-before-property": "error"

规定属性前面不能加空格。


object-property-newline

"object-property-newline": ["error",{ "allowMultiplePropertiesPerLine": true }]

规定对象属性换行时注意统一代码风格(要么都换行,要么都不换)。第二个参数是一个对象,配置是否允许在一行代码中书写多个属性。代码示例如下:

const user = {
  name: 'Jane Doe',age: 30,username: 'jdoe86'            // ? avoid
}

const user = { name: 'Jane Doe',username: 'jdoe86' }    // ? ok

const user = {
  name: 'Jane Doe',username: 'jdoe86'
}


operator-linebreak

"operator-linebreak": ["error","after",{ "overrides": { "?": "before",":": "before" } }]

规定对于三元运算符 ?: 与他们所负责的代码处于同一行。第二个参数配置换行符位置,可配“after”、“before”、“none”,分别表示操作符之后可换行,操作符之前可换行,前后都不允许换行。第三个参数配置覆盖第二个参数的配置内容。代码示例如下:

// ? ok
var location = env.development ? 'localhost' : 'www.api.com'

// ? ok
var location = env.development
  ? 'localhost'
  : 'www.api.com'

// ? avoid
var location = env.development ?
  'localhost' :
  'www.api.com'


padded-blocks

"padded-blocks": ["error",{ "blocks": "never","switches": "never","classes": "never" }]

规则定义代码中不要啊出现多余留白。第二个参数是一个对象,有以下属性配置。“blocks”表代码块,“classes”表类,“switches”表switch语句,取值都为“never”或“always”,表示是否需要留空行。代码示例如下:

if (user) {
                            // ? avoid
  const name = getName()

}

if (user) {
  const name = getName()    // ? ok
}


rest-spread-spacing

"rest-spread-spacing": ["error","never"]

规定展开运算符与它的表达式间不要留空白。第二个参数取值“never”和“always”,表是否需要留白。代码示例如下:

fn(... args)    // ? avoid
fn(...args)     // ? ok


semi-spacing

"semi-spacing": ["error","after": true }]

规定分号前不留空格,后面留一个空格。第二个参数就是配置前后空格开关的。代码示例如下:

for (let i = 0 ;i < items.length ;i++) {...}    // ? avoid
for (let i = 0; i < items.length; i++) {...}    // ? ok


space-before-blocks

"space-before-blocks": ["error","always"]

规定代码块收尾需留空格。第二个参数配置是否需要空格。代码示例如下:

if (admin){...}     // ? avoid
if (admin) {...}    // ? ok


space-before-function-paren

"space-before-function-paren": ["error","always"]

规定函数声明时括号与函数名间加空格。第二个参数配置是否需要空格。代码示例如下:

function name (arg) { ... }   // ? ok
function name(arg) { ... }    // ? avoid

run(function () { ... })      // ? ok
run(function() { ... })       // ? avoid


space-in-parens

"space-in-parens": ["error","never"]

规定圆括号间不留空格。第二个参数配置是否需要空格。代码示例如下:

getName( name )     // ? avoid
getName(name)       // ? ok


space-infix-ops

"space-infix-ops": "error"

规定字符串拼接操作符 (Infix operators) 之间要留空格。代码示例如下:

// ? ok
var x = 2
var message = 'hello,' + name + '!'

// ? avoid
var x=2
var message = 'hello,'+name+'!'


space-unary-ops

"space-unary-ops": ["error",{ "words": true,"nonwords": false }]

规定文字格式的一元运算符后跟一个空格。第二个参数有三个属性,“words”表文字格式的运算符(new,delete,typeof,void,yield),"nonwords"表非文字运算符(-,+,--,++,!,!!),"overrides"配置一个对象值,配置具体操作符的空格行为。代码示例如下:

typeof!admin        // ? avoid
typeof !admin        // ? ok


template-curly-spacing

"template-curly-spacing": ["error","never"]

规定模板字符串中变量前后不加空格。第二个参数配置是否需要空格。代码示例如下:

const message = `Hello,${ name }`    // ? avoid
const message = `Hello,${name}`      // ? ok


yield-star-spacing

"yield-star-spacing": ["error","both"]

规定yield 中的 前后都要有空格。第二个参数取值“before”、“after”、“both”、“neither”,分别表示前留、后留、都留和都不留。代码示例如下:

yield* increment()    // ? avoid
yield * increment()   // ? ok


generator-star-spacing

"generator-star-spacing": ["error",{ "before": true,"after": true }]

规定生成器函数*的前后都要留空格。


可能出错代码

accessor-pairs

"accessor-pairs": "error"

规定get和set成对出现。代码示例如下:

var person = {
  set name (value) {    // ? avoid
    this.name = value
  }
}

var person = {
  set name (value) {
    this.name = value
  },get name () {         // ? ok
    return this.name
  }
}


comma-dangle

"comma-dangle": ["error",{
    "arrays": "never","objects": "never","imports": "never","exports": "never","functions": "never"
}]

规定不允许多余的行末逗号。第二个参数可配置属性,“arrays”、“objects”、“imports”、“exports”、“functions”,值分别取“never”或“always”。代码示例如下:

var obj = {
    message: 'hello',// ? avoid
  }


comma-style

"comma-style": ["error","last"]

规定始终将逗号置于行末。第二个参数取值“last”或“first”,分别表示行末或行首。代码示例如下:

var obj = {
    foo: 'foo',bar: 'bar'   // ? avoid
  }

  var obj = {
    foo: 'foo',bar: 'bar'   // ? ok
  }


constructor-super

"constructor-super": "error"

规定子类构造函数中必须调用super,非子类不要调用super。代码示例如下:

class Dog {
  constructor () {
    super()   // ? avoid
  }
}

class Dog extends Mammal {
  constructor () {
    super()   // ? ok
  }
}


eqeqeq

"eqeqeq": ["error","always",{ "null": "ignore" }]

规定始终使用 === 替代 ==,null除外。第二个参数配置是否使用 === ,第三个参数配置是否忽略空值判断。示例代码如下:

if (name === 'John')   // ? ok
if (name == 'John')    // ? avoid
if (name !== 'John')   // ? ok
if (name != 'John')    // ? avoid


handle-callback-err

"handle-callback-err": ["error","^(err|error)$" ]

规定函数里面的异常信息不要忘记处理。第二个参数配置匹配那些参数的正则表达式。示例代码如下:

// ? ok
run(function (err) {
  if (err) throw err
  window.alert('done')
})

// ? avoid
run(function (err) {
  window.alert('done')
})


new-parens

"new-parens": "error"

规定无参的构造函数调用时要带上括号。代码示例如下:

function Animal () {}
var dog = new Animal    // ? avoid
var dog = new Animal()  // ? ok


no-array-constructor

"no-array-constructor": "error"

规定使用数组字面量而不是构造器(由于参数的二义性),但是我们可以在初始化一个固定大小数组时用到他。代码示例如下:

var nums = new Array(1,3)   // ? avoid
var nums = [1,3]            // ? ok


no-class-assign

"no-class-assign": "error"

规定避免对类名重新赋值。代码示例如下:

class Dog {}
Dog = 'Fido'    // ? avoid


no-const-assign

"no-const-assign": "error"

规定避免修改使用 const 声明的变量。代码示例如下:

const score = 100
score = 125       // ? avoid


no-constant-condition

"no-constant-condition": ["error",{ "checkLoops": false }]

规定避免使用常量作为条件表达式的条件(循环语句除外)。第二个参数配置是否检查循环表达式。代码示例如下:

if (false) {    // ? avoid
  // ...
}

if (x === 0) {  // ? ok
  // ...
}

while (true) {  // ? ok
  // ...
}


no-delete-var

"no-delete-var": "error"

规定不要对变量使用 delete 操作。代码示例如下:

var name
delete name     // ? avoid


no-dupe-args

"no-dupe-args": "error"

规定不要定义重复的函数参数。代码示例如下:

function sum (a,b,a) {  // ? avoid
  // ...
}

function sum (a,c) {  // ? ok
  // ...
}


no-dupe-class-members

"no-dupe-class-members": "error"

规定类中不要定义重复的属性。代码示例如下:

class Dog {
  bark () {}
  bark () {}    // ? avoid
}


no-dupe-keys

"no-dupe-keys": "error"

规定对象字面量中不要定义重复的属性。代码示例如下:

var user = {
  name: 'Jane Doe',name: 'John Doe'    // ? avoid
}


no-duplicate-case

"no-duplicate-case": "error"

规定switch 语句中不要定义重复的 case 分支。代码示例如下:

switch (id) {
  case 1:
    // ...
  case 1:     // ? avoid
}


no-empty-character-class

"no-empty-character-class": "error"

规定正则中不要使用空字符。代码示例如下:

const myRegex = /^abc[]/      // ? avoid
const myRegex = /^abc[a-z]/   // ? ok


no-empty-pattern

"no-empty-pattern": "error"

规定不要解构空值。代码示例如下:

const { a: {} } = foo         // ? avoid
const { a: { b } } = foo      // ? ok


no-ex-assign

"no-ex-assign": "error"

定义catch 中不要对错误重新赋值。代码示例如下:

try {
  // ...
} catch (e) {
  e = 'new value'             // ? avoid
}

try {
  // ...
} catch (e) {
  const newVal = 'new value'  // ? ok
}


no-fallthrough

"no-fallthrough": "error"

规定switch一定要使用 break 来将条件分支正常中断。代码示例如下:

switch (filter) {
  case 1:
    doSomething()    // ? avoid
  case 2:
    doSomethingElse()
}

switch (filter) {
  case 1:
    doSomething()
    break           // ? ok
  case 2:
    doSomethingElse()
}

switch (filter) {
  case 1:
    doSomething()
    // fallthrough  // ? ok
  case 2:
    doSomethingElse()
}


no-func-assign

"no-func-assign": "error"

规定避免对声明过的函数重新赋值。代码示例如下:

function myFunc () { }
myFunc = myOtherFunc    // ? avoid


no-global-assign

"no-global-assign": "error"

规定不要对全局只读对象重新赋值。代码示例如下:

window = {}     // ? avoid


no-invalid-regexp

"no-invalid-regexp": "error"

规定不要向 RegExp 构造器传入非法的正则表达式。代码示例如下:

RegExp('[a-z')    // ? avoid
RegExp('[a-z]')   // ? ok


no-iterator

"no-iterator": "error"

规定禁止使用 __iterator__。代码示例如下:

Foo.prototype.__iterator__ = function () {}   // ? avoid


no-self-assign

"no-self-assign": "error"

规定避免将变量赋值给自己。代码示例如下:

name = name   // ? avoid


no-self-compare

"no-self-compare": "error"

规定避免将变量与自己进行比较操作。代码示例如下:

if (score === score) {}   // ? avoid


no-shadow-restricted-names

"no-shadow-restricted-names": "error"

规定禁止随意更改关键字的值。代码示例如下:

let undefined = 'value'     // ? avoid


no-sparse-arrays

"no-sparse-arrays": "error"

规定禁止使用稀疏数组。代码示例如下:

let fruits = ['apple','orange']       // ? avoid


no-template-curly-in-string

"no-template-curly-in-string": "error"

规定正确使用 ES6 中的字符串模板。代码示例如下:

const message = 'Hello ${name}'   // ? avoid
const message = `Hello ${name}`   // ? ok


no-throw-literal

"no-throw-literal": "error"

规定用throw 抛错时,抛出 Error 对象而不是字符串。代码示例如下:

throw 'error'               // ? avoid
throw new Error('error')    // ? ok


no-unexpected-multiline

"no-unexpected-multiline": "error"

规定不要使用 (,[,or ` 等作为一行的开始。在没有分号的情况下代码压缩后会导致报错,而坚持这一规范则可避免出错。代码示例如下:

// ? ok
;(function () {
  window.alert('ok')
}())

// ? avoid
(function () {
  window.alert('ok')
}())

// ? ok
;[1,3].forEach(bar)

// ? avoid
[1,3].forEach(bar)

// ? ok
;`hello`.indexOf('o')

// ? avoid
`hello`.indexOf('o')


no-unmodified-loop-condition

"no-unmodified-loop-condition": "error"

规定循环语句中注意更新循环变量。代码示例如下:

for (let i = 0; i < items.length; j++) {...}    // ? avoid
for (let i = 0; i < items.length; i++) {...}    // ? ok


no-unreachable

"no-unreachable": "error"

规定return,throw,continue 和 break 后不要再跟代码。代码示例如下:

function doSomething () {
  return true
  console.log('never called')     // ? avoid
}


no-unsafe-finally

"no-unsafe-finally": "error"

规定finally 代码块中不要再改变程序执行流程。代码示例如下:

try {
  // ...
} catch (e) {
  // ...
} finally {
  return 42     // ? avoid
}


valid-typeof

"valid-typeof": ["error",{ "requireStringLiterals": true }]

规定用合法的字符串跟 typeof 进行比较操作。第二个参数配置是否只和字符串比对。代码示例如下:

typeof name === 'undefimed'     // ? avoid
typeof name === 'undefined'     // ? ok
typeof bar == Object           // ? avoid


no-control-regex

"no-control-regex": "error"

规定禁止在正则表达式中使用控制字符。代码示例如下:

var pattern = /x1f/    // ? avoid
var pattern = /x20/    // ? ok


no-unused-expressions

"no-unused-expressions": ["error",{ "allowShortCircuit": true,"allowTernary": true,"allowTaggedTemplates": true }]

规定禁止无用的表达式。


no-use-before-define

"no-use-before-define": ["error",{ "functions": false,"classes": false,"variables": false }]

规定未定义前不能使用。

最佳实践

accessor-pairs

"accessor-pairs": "error"

对象中定义了存值器,一定要定义对应的取值器。代码示例如下:

var person = {
  set name (value) {    // ? avoid
    this.name = value
  }
}

var person = {
  set name (value) {
    this.name = value
  },get name () {         // ? ok
    return this.name
  }
}


no-caller

"no-caller": "error"

规定避免使用 arguments.callee 和 arguments.caller(不利于代码优化,且高级版本的ES标准会废弃它)。代码示例如下:

function foo (n) {
  if (n <= 0) return

  arguments.callee(n - 1)   // ? avoid
}

function foo (n) {
  if (n <= 0) return

  foo(n - 1)
}


no-cond-assign

"no-cond-assign": "error"

规定条件语句中赋值语句使用括号包起来。代码示例如下:

// ? ok
while ((m = text.match(expr))) {
  // ...
}

// ? avoid
while (m = text.match(expr)) {
  // ...
}


no-debugger

"no-debugger": "error"

规定不要使用 debugger。


no-eval

"no-eval": "error"

规定不要使用 eval()。


no-extend-native

"no-extend-native": "error"

规定不要扩展原生对象。


no-extra-bind

"no-extra-bind": "error"

规定避免多余的函数上下文绑定。代码示例如下:

const name = function () {
  getName()
}.bind(user)    // ? avoid

const name = function () {
  this.getName()
}.bind(user)    // ? ok


no-extra-boolean-cast

"no-extra-boolean-cast": "error"

规定避免不必要的布尔转换。代码示例如下:

const result = true
if (!!result) {   // ? avoid
  // ...
}

const result = true
if (result) {     // ? ok
  // ...
}


no-extra-parens

"no-extra-parens": ["error","functions"]

规定不要使用多余的括号包裹函数。第二个参数取值“all”或“functions”,表控制范围。代码示例如下:

const myFunc = (function () { })   // ? avoid
const myFunc = function () { }     // ? ok


no-floating-decimal

"no-floating-decimal": "error"

规定不要省去小数点前面的0(增强可读性)。代码示例如下:

const discount = .5      // ? avoid
const discount = 0.5     // ? ok


no-implied-eval

"no-implied-eval": "error"

规定避免使用隐式的 eval()。代码示例如下:

setTimeout("alert('Hello world')")                   // ? avoid
setTimeout(function () { alert('Hello world') })     // ? ok


no-inner-declarations

"no-inner-declarations": ["error","functions"]

规定嵌套的代码块中禁止再定义函数。第二个参数配置控制范围,取值“both”(functions+var)、“functions”。代码示例如下:

if (authenticated) {
  function setAuthUser () {}    // ? avoid
}


no-irregular-whitespace

"no-irregular-whitespace": "error"

规定不要使用非法的空白符。代码示例如下:

function myFunc () /*<NBSP>*/{}   // ? avoid


no-labels

"no-labels": ["error",{ "allowLoop": false,"allowSwitch": false }]

规定不要使用标签语句。第二个参数含两个属性,“allowLoop”配置是否在循环语句中禁用,“allowSwitch”配置是否在switch语句中禁用。代码示例如下:

label:
  while (true) {
    break label     // ? avoid
  }


no-lone-blocks

"no-lone-blocks": "error"

规定不要书写不必要的嵌套代码块。代码示例如下:

function myFunc () {
  {                   // ? avoid
    myOtherFunc()
  }
}

function myFunc () {
  myOtherFunc()       // ? ok
}


no-multi-str

"no-multi-str": "error"

规定不要使用多行字符串。代码示例如下:

const message = 'Hello 
                 world'     // ? avoid


no-new

"no-new": "error"

规定new 创建对象实例后需要赋值给变量。代码示例如下:

new Character()                     // ? avoid
const character = new Character()   // ? ok


no-new-func

"no-new-func": "error"

规定禁止使用 Function 构造器。代码示例如下:

var sum = new Function('a','b','return a + b')    // ? avoid


no-new-object

"no-new-object": "error"

规定禁止使用 Object 构造器,直接声明对象即可。代码示例如下:

let config = new Object()   // ? avoid


no-new-require

"no-new-require": "error"

规定禁止使用 new require。代码示例如下:

const myModule = new require('my-module')    // ? avoid


no-new-symbol

"no-new-symbol": "error"

规定禁止使用 Symbol 构造器。代码示例如下:

const foo = new Symbol('foo')   // ? avoid


no-new-wrappers

"no-new-wrappers": "error"

规定禁止使用原始包装器。代码示例如下:

const message = new String('hello')   // ? avoid


no-obj-calls

"no-obj-calls": "error"

规定不要将全局对象的属性作为函数调用。代码示例如下:

const math = Math()   // ? avoid


no-octal

"no-octal": "error"

规定不要使用八进制字面量。代码示例如下:

const num = 042     // ? avoid
const num = '042'   // ? ok


no-octal-escape

"no-octal-escape": "error"

规定字符串字面量中也不要使用八进制转义字符。代码示例如下:

const copyright = 'Copyright 251'  // ? avoid


no-proto

"no-proto": "error"

规定使用 getPrototypeOf 来替代 __proto__。代码示例如下:

const foo = obj.__proto__               // ? avoid
const foo = Object.getPrototypeOf(obj)  // ? ok


no-redeclare

"no-redeclare": "error"

规定不要重复声明变量。代码示例如下:

let name = 'John'
let name = 'Jane'     // ? avoid

let name = 'John'
name = 'Jane'         // ? ok


no-regex-spaces

"no-regex-spaces": "error"

规定正则中避免使用多个空格。代码示例如下:

const regexp = /test   value/   // ? avoid

const regexp = /test {3}value/  // ? ok
const regexp = /test value/     // ? ok


no-return-assign

"no-return-assign": ["error","except-parens"]

规定return 语句中的赋值必需有括号包裹。代码示例如下:

function sum (a,b) {
  return result = a + b     // ? avoid
}

function sum (a,b) {
  return (result = a + b)   // ? ok
}


no-sequences

"no-sequences": "error"

规定避免使用逗号操作符。代码示例如下:

if (doSomething(),!!test) {}   // ? avoid


no-undef-init

"no-undef-init": "error"

规定不要使用 undefined 来初始化变量。代码示例如下:

let name = undefined    // ? avoid

let name
name = 'value'          // ? ok


no-unneeded-ternary

"no-unneeded-ternary": ["error",{ "defaultAssignment": false }]

规定如果有更好的实现,尽量不要使用三元表达式。代码示例如下:

let score = val ? val : 0     // ? avoid
let score = val || 0          // ? ok


no-unsafe-negation

"no-unsafe-negation": "error"

规定关系运算符的左值不要做取反操作。代码示例如下:

if (!key in obj) {}       // ? avoid


no-unused-vars

"no-unused-vars": ["error",{ "vars": "all","args": "none","ignoreRestSiblings": true }]

规定不要定义未使用的变量。代码示例如下:

function myFunction () {
  var result = something()   // ? avoid
}


no-useless-call

"no-useless-call": "error"

规定避免不必要的 .call() 和 .apply()。代码示例如下:

sum.call(null,1,3)   // ? avoid


no-useless-computed-key

"no-useless-computed-key": "error"

规定避免使用不必要的计算值作对象属性。代码示例如下:

const user = { ['name']: 'John Doe' }   // ? avoid
const user = { name: 'John Doe' }       // ? ok


no-useless-constructor

"no-useless-constructor": "error"

规定禁止多余的构造器(ES2015会自动生成一个简单构造器)。代码示例如下:

class Car {
  constructor () {      // ? avoid
  }
}


no-useless-escape

"no-useless-escape": "error"

规定禁止不必要的转义。代码示例如下:

let message = 'Hello'  // ? avoid


no-useless-rename

"no-useless-rename": "error"

规定import,export 和解构操作中,禁止赋值到同名变量。代码示例如下:

import { config as config } from './config'     // ? avoid
import { config } from './config'               // ? ok


no-with

"no-with": "error"

规定禁止使用 with。代码示例如下:

with (val) {...}    // ? avoid


one-var

"one-var": ["error",{ "initialized": "never" }]

规定每个 var 关键字单独声明一个变量。代码示例如下:

// ? ok
var silent = true
var verbose = true

// ? avoid
var silent = true,verbose = true

// ? avoid
var silent = true,verbose = true


quotes

"quotes": ["error","single",{ "avoidEscape": true,"allowTemplateLiterals": true }]

规定除需要转义的情况外,字符串统一使用单引号。第二个参数取值“single”、“double”,分别表示单引号和双引号。第三个参数配置是否允许嵌套和是否允许字符串模板。代码示例如下:

console.log('hello there')
$("<div class='box'>")


semi

"semi": ["error","always"]

规定必须添加分号。第二个参数配置开关取值“never”、“always”。代码示例如下:

window.alert('hi')   // ? ok
window.alert('hi');  // ? avoid


use-isnan

"use-isnan": "error"

规定检查 NaN 的正确姿势是使用 isNaN()。


wrap-iife

"wrap-iife": ["error","any",{ "functionPrototypeMethods": true }]

规定自调用匿名函数 (IIFEs) 使用括号包裹。代码示例如下:

const getName = function () { }()     // ? avoid

const getName = (function () { }())   // ? ok
const getName = (function () { })()   // ? ok


arrow-spacing

"arrow-spacing": ["error","after": true }]

规定箭头函数必须有前后括号。


命名

new-cap

"new-cap": ["error",{ "newIsCap": true,"capIsNew": false }]

规定构造函数要以大写字母开头。第二个参数配置细则,"newIsCap"配置只要是new关键字初始化的函数,首字母必须大写;“capIsNew”配置是否允许大写字母开头的函数不使用new关键字初始化。代码示例如下:

function animal () {}
var dog = new animal()    // ? avoid

function Animal () {}
var dog = new Animal()    // ? ok

function Animal () {}
var dog = Animal()    // ? ok


camelcase

"camelcase": ["error",{ "properties": "never" }]

规定变量和函数使用驼峰命名法。第二个参数配置对象属性是否也要遵循驼峰命名法。示例代码如下:

function my_function () { }    // ? avoid
  function myFunction () { }     // ? ok

  var my_var = 'hello'           // ? avoid
  var myVar = 'hello'            // ? ok


Angular规则

angular/no-private-call

"angular/no-private-call":["error"]

规定使用直接使用angular中带$$符号的成员,他们都是私有成员。


angular/di-unused

"angular/di-unused":["error"]

规定不要注入不使用的服务。


angular/empty-controller

"angular/empty-controller":["error"]

规定控制器不能为空。


angular/no-run-logic

"angular/no-run-logic":["error"]

规定控制器中只有调用代码,没有声明逻辑。


angular/no-cookiestore

"angular/no-cookiestore":["error"]

规定取代$cookiesStore,而使用$cookie来操作缓存。


angular/no-directive-replace

"angular/no-directive-replace":["error"]

规定自定义指令中不能使用replace属性。


angular/no-http-callback

"angular/no-http-callback":["error"]

规定不要直接使用 $http 的回调函数,应该使用promise来操作回调。


angular/controller-name

"angular/controller-name":["error","/[a-z].*Ctrl/"]

规定控制器命名规则,以小写字母开头以“Ctrl”结尾。


angular/di

"angular/di":["error","array"]

规定依赖注入规则,必须有数组列表并且参数与之一致。


angular/function-type

"angular/function-type":["error","anonymous"]

规定为angular组件指定一致的函数风格——匿名函数。


angular/document-service

"angular/document-service":["off"]

规定使用$document。


angular/interval-service

"angular/interval-service":["off"]

规定使用$interval。


angular/log

"angular/log":["off"]

规定使用$log。


angular/timeout-service

"angular/timeout-service":["off"]

规定使用$timeout。


angular/window-service

"angular/window-service":["off"]

规定使用$window。



参考文章:

https://github.com/standard/standard/blob/master/docs/RULES-zhcn.md#javascript-standard-style

http://eslint.cn/


欢迎关注我的微信公众号:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读