我是不是遗漏了什么?
var someNumber = 123.456;
someNumber = someNumber.toFixed(2);
alert(typeof(someNumber));
//alerts string
为什么.toFixed()返回一个字符串?
我想把这个数四舍五入到两位十进制数字。
我是不是遗漏了什么?
var someNumber = 123.456;
someNumber = someNumber.toFixed(2);
alert(typeof(someNumber));
//alerts string
为什么.toFixed()返回一个字符串?
我想把这个数四舍五入到两位十进制数字。
当前回答
小心使用toFixed()和Math.round(),由于浮点数系统,它们可能会产生意想不到的结果:
function toFixedNumber(num, digits, base){
var pow = Math.pow(base||10, digits);
return Math.round(num*pow) / pow;
}
console.log(toFixedNumber(130.795, 2, 10));
// 130.79 (incorrect)
console.log(toFixedNumber(100.795, 2, 10));
// 100.8
console.log(+130.795.toFixed(2));
// 130.79 (incorrect)
console.log(+100.795.toFixed(2));
// 100.8
我建议使用Lodash的_.round()函数:https://lodash.com/docs/4.17.15#round
_.round(130.795, 2);
// 130.8
其他回答
当然它会返回一个字符串。如果要对数值变量进行四舍五入,则应该使用Math.round()。toFixed的目的是用固定的小数位数格式化数字,以便显示给用户。
我通过修改这个来解决这个问题:
someNumber = someNumber.toFixed(2)
...:
someNumber = +someNumber.toFixed(2);
然而,这会将数字转换为字符串并再次解析它,这将对性能产生重大影响。如果您关心性能或类型安全,也请检查其他答案。
可能来不及回答,但您可以将输出与1相乘以再次转换为数字,这里是一个例子。
Const x1 = 1211.1212121; const x2 = x1.toFixed(2)*1; console.log (typeof (x2));
为什么不使用parseFloat呢?
var someNumber = 123.456;
someNumber = parseFloat(someNumber.toFixed(2));
alert(typeof(someNumber));
//alerts number
提供一个为什么它必须是字符串的例子:
如果你格式化1.toFixed(2),你会得到'1.00'。
这和1不一样,因为1没有两个小数。
我知道JavaScript并不是一种精确的性能语言,但如果你使用以下内容,你可能会获得更好的性能: roundedValue =数学。整数(值* 100)* 0.01