我在这段 JavaScript 代码上运行了 JSLint,它说:
第 32 行字符 30 处的问题:缺少基数参数。
这是有问题的代码:
imageIndex = parseInt(id.substring(id.length - 1))-1;
这里有什么问题?
我在这段 JavaScript 代码上运行了 JSLint,它说:
第 32 行字符 30 处的问题:缺少基数参数。
这是有问题的代码:
imageIndex = parseInt(id.substring(id.length - 1))-1;
这里有什么问题?
使用 parseInt 传递基数总是一个好习惯 -
parseInt(string, radix)
对于十进制 -
parseInt(id.substring(id.length - 1), 10)
如果 radix 参数被省略,JavaScript 假设如下:
(参考)
为了避免这个警告,而不是使用:
parseInt("999", 10);
您可以将其替换为:
Number("999");
请注意 parseInt 和 Number 有不同的行为,但在某些情况下,一个可以替换另一个。
我没有正确回答这个问题,但我认为明确为什么我们应该指定 radix 是有道理的。
在 MDN 文档中,我们可以读到:
如果 radix 未定义或为 0(或不存在),JavaScript 假定如下:
- [...]
- 如果输入字符串以“0”开头,则基数为 8(八进制)或 10(十进制)。确切选择哪个基数取决于实现。 ECMAScript 5 指定使用 10(十进制),但并非所有浏览器都支持这一点。由于这个原因,在使用 parseInt 时总是指定一个基数。
- [...]
如果您希望跳过该测试,您可以关闭此规则。
插入:
radix: false
在文件中的“ rules
”属性下tslint.json
。
如果您不了解此异常,不建议这样做。
在 ECMAScript 5 之前,parseInt() 还自动检测八进制文字,这会导致问题,因为许多开发人员认为前导 0 会被忽略。
所以而不是:
var num = parseInt("071"); // 57
做这个:
var num = parseInt("071", 10); // 71
var num = parseInt("071", 8);
var num = parseFloat(someValue);
我只使用 +foo 来转换字符串就解决了这个问题。
请记住,它不利于可读性(脏修复)。
console.log( +'1' )
// 1 (int)
您也可以简单地将这一行添加到您的 parseInt 行的正上方:
// eslint-disable-next-line
这将禁用下一行的 eslint 检查。如果您只需要跳过一两行,请使用此选项。
只需在 .eslintrc 中添加您的自定义规则,看起来像这样
"radix": "off"
,您将摆脱这个 eslint unnesesery 警告。这是为 eslint linter 准备的。
只需在基数位置放一个空字符串,因为 parseInt() 有两个参数:
parseInt(字符串,基数);
string 要解析的值。如果字符串参数不是字符串,则将其转换为字符串(使用 ToString 抽象操作)。字符串参数中的前导空格被忽略。
radix 2 到 36 之间的整数,表示上述字符串的基数(数学数字系统中的基数)。为人类常用的十进制数字系统指定 10。始终指定此参数以消除读者混淆并保证可预测的行为。当未指定基数时,不同的实现会产生不同的结果,通常将值默认为 10。
imageIndex = parseInt(id.substring(id.length - 1))-1;
imageIndex = parseInt(id.substring(id.length - 1), '')-1;
而不是调用substring
你可以使用的函数.slice()
imageIndex = parseInt(id.slice(-1)) - 1;
这里,-1 in slice 表示从最后一个索引开始切片。
谢谢。