Eslint
规则 | Rules

no-implicit-coercion

不允许使用较短的符号进行类型转换。( no-implicit-coercion )

--fix命令行上的选项可以自动修复一些被这条规则反映的问题。

在 JavaScript 中,有很多不同的方法来转换值类型。其中一些可能难以阅读和理解。

如:

var b = !!foo; var b = ~foo.indexOf("." var n = +foo; var n = 1 * foo; var s = "" + foo; foo += ``;

这些可以用下面的代码替换:

var b = Boolean(foo var b = foo.indexOf(".") !== -1; var n = Number(foo var n = Number(foo var s = String(foo foo = String(foo

规则细节

该规则旨在标记类型转换的较短符号,然后提供一个更加明了的符号。

选项

该规则有三个主要选项和一个覆盖选项,以根据需要允许一些强制。

  • "boolean"true默认情况下) - 发生这种情况时true,此规则会警告类型的类型转换较短boolean

  • "number"true默认情况下) - 发生这种情况时true,此规则会警告类型的类型转换较短number

  • "string"true默认情况下) - 发生这种情况时true,此规则会警告string类型的转换较短类型。

  • "allow"empty默认) -此数组中的每个条目可以是一个~!!+*将被允许的。

需要注意的是运营商+allow名单将允许+foo(数字胁迫)以及"" + foo(字符串强制)。

boolean

不正确的代码为默认{ "boolean": true }选项的示例:

/*eslint no-implicit-coercion: "error"*/ var b = !!foo; var b = ~foo.indexOf("." // bitwise not is incorrect only with `indexOf`/`lastIndexOf` method calling.

默认选项的正确代码示例{ "boolean": true }

/*eslint no-implicit-coercion: "error"*/ var b = Boolean(foo var b = foo.indexOf(".") !== -1; var n = ~foo; // This is a just bitwise not.

number

不正确的代码为默认{ "number": true }选项的示例:

/*eslint no-implicit-coercion: "error"*/ var n = +foo; var n = 1 * foo;

默认选项的正确代码示例{ "number": true }

/*eslint no-implicit-coercion: "error"*/ var n = Number(foo var n = parseFloat(foo var n = parseInt(foo, 10

string

不正确的代码为默认{ "string": true }选项的示例:

/*eslint no-implicit-coercion: "error"*/ var s = "" + foo; var s = `` + foo; foo += ""; foo += ``;

默认选项的正确代码示例{ "string": true }

/*eslint no-implicit-coercion: "error"*/ var s = String(foo foo = String(foo

allow

使用allow列表,我们可以覆盖并允许特定的操作符。

示例选项的正确代码示例{ "allow": ["!!", "~"] }

/*eslint no-implicit-coercion: [2, { "allow": ["!!", "~"] } ]*/ var b = !!foo; var b = ~foo.indexOf("."

何时不使用它

如果您不希望收到有关类型转换的简短符号的通知,则可以安全地禁用此规则。

版本

该规则在 ESLint 1.0.0-rc-2 中引入。

资源