JavaScript中科学计数法转化为数值字符串形式

简介: JavaScript中科学计数法转化为数值字符串形式

精度计算的时候我们通常会使用 .toFixed() 方法,Number.toFixed(digits) 方法使用定点表示法来格式化一个数,会对结果进行四舍五入。参数 digits 表示小数点后数字的个数,一般介于 0 到 20 (包括)之间。例如:

JavaScript 代码:

3.3e-7.toFixed(8); // “0.00000033”
3e-7.toFixed(8); // “0.00000030”

一般情况下,我们的需求小数位数是固定的,所以这个基本可以满足我们的需求。但是有些人可能不喜欢 0.00000030 这种形式,认为最后的 0 是多余的。所以索性就改进了一下:

JavaScript 代码:

function toNumberStr(num,digits) {
// 正则匹配小数科学记数法
if (/^(\d+(?:.\d+)?)(e)([-]?\d+)$/.test(num)) {
// 正则匹配小数点最末尾的0
var temp=/^(\d{1,}(?:,\d{3}).(?:0[1-9]+)?)(0*)?$/.exec(num.toFixed(digits)) ;
if(temp){
return temp[1];
}else{
return num.toFixed(digits)
}
}else{
return “”+num
}
}
toNumberStr(3.3e-7,8) // “0.00000033”
toNumberStr(3e-7,8) // “0.0000003”
toNumberStr(1.401e10,8) // “14010000000”
toNumberStr(0.0004,8) // “0.0004”

这个方法基本满足了我的需求,但是总是觉得一点累赘,后面那个参数意思也不够明确,所以发到微信群请大家帮忙优化。特别感谢网友 @caikan 提供的方法:

JavaScript 代码:

function toNonExponential(num) {
var m = num.toExponential().match(/\d(?:.(\d*))?e([±]\d+)/);
return num.toFixed(Math.max(0, (m[1] || ‘’).length - m[2]));
}
toNonExponential(3.3e-7) // “0.00000033”
toNonExponential(3e-7) // “0.0000003”
toNonExponential(1.401e10) // “14010000000”
toNonExponential(0.0004) // “0.0004”
相关文章
|
1天前
|
JavaScript 前端开发
JavaScript进阶-模板字符串与增强的对象字面量
【6月更文挑战第19天】ES6的模板字符串和增强对象字面量提高了JavaScript的易读性和效率。模板字符串(` `)支持变量嵌入和多行,简化了字符串处理;增强对象字面量允许简写属性与方法,以及动态属性名。注意模板字符串的闭合和性能影响,以及对象字面量的简写语法和计算属性名的恰当使用。通过实例展示了这两项特性的应用,助力编写更优雅的代码。
|
5天前
|
JSON JavaScript 前端开发
js将json字符串还原为json
【6月更文挑战第15天】js将json字符串还原为json
11 4
|
6天前
|
JavaScript
请用 js 去除字符串空格?
请用 js 去除字符串空格?
|
6天前
|
JavaScript 前端开发
JS字符串拼接的几种方式
JS字符串拼接的几种方式
|
6天前
|
JavaScript 前端开发
JavaScript如何去除字符串中的汉字?
在JavaScript中,要在一个包含汉字、数字和字母的字符串中去除所有的汉字,该怎么办呢?
14 0
|
9天前
|
存储 JavaScript 前端开发
JavaScript基础-字符串操作方法
【6月更文挑战第11天】本文介绍了JavaScript中字符串的基本操作,包括创建与访问、查找与替换、大小写转换等,并强调了字符串的不可变性。通过实例代码展示了如何避免常见错误,如混淆查找与替换方法、正则表达式使用不当。学习这些技巧能提升代码健壮性和效率。
|
1月前
|
前端开发 JavaScript 流计算
前端 js 经典:字符串超全方法总结
前端 js 经典:字符串超全方法总结
30 0
|
1月前
|
JSON JavaScript 前端开发
js将json字符串还原为json对象
【5月更文挑战第14天】js将json字符串还原为json对象
48 1
|
1月前
|
存储 JavaScript 前端开发
JavaScript字符串方法详解
JavaScript字符串方法详解
26 0
|
9月前
|
JavaScript
js截取,拼接,字符串方法
js截取,拼接,字符串方法

热门文章

最新文章