我在这个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假设如下:

如果字符串以“0x”开头,则基数为16(十六进制) 如果字符串以“0”开头,则基数为8(八进制)。此特性已弃用 如果字符串以任何其他值开头,则基数为10(十进制)

(参考)

其他回答

你也可以简单地将这一行添加到你的parseInt行上面:

// eslint-disable-next-line

这将禁用下一行的eslint检查。如果你只需要跳过一两行就可以使用这个方法。

为了避免这个警告,不要使用:

parseInt("999", 10);

你可以用:

Number("999");

注意,parseInt和Number有不同的行为,但在某些情况下,一个可以替换另一个。

用parseInt -传递基数始终是一个很好的做法

parseInt(string, radix)

对于十进制-

parseInt(id.substring(id.length - 1), 10)

如果省略了radix参数,JavaScript假设如下:

如果字符串以“0x”开头,则基数为16(十六进制) 如果字符串以“0”开头,则基数为8(八进制)。此特性已弃用 如果字符串以任何其他值开头,则基数为10(十进制)

(参考)

你可以使用.slice()代替调用子字符串函数

    imageIndex = parseInt(id.slice(-1)) - 1;

这里,slice中的-1表示从最后一个索引开始切片。

谢谢。

我只用+foo来转换字符串。

请记住,这对可读性不是很好(肮脏的修复)。

console.log( +'1' )
// 1 (int)