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 中引入。