js处理数字科学计数法的显示问题,完美解决数字显示中的'e'和'E'

一,科学计数法

科学记数法是一种记数的方法。把一个数表示成a与10的n次幂相乘的形式(1≤a<10,n为整数),这种记数法叫做科学记数法。当我们要标记或运算某个较大或较小且位数较多时,用科学记数法免去浪费很多空间和时间。

二,js计算中的科学计数法

js的运算与数据传递过程中,会把较大的数字用科学计数法来显示


  var d=0.00000000002;
  console.log(d);//2e-11
  console.log('0.00000000002'.length)//13
  console.log('0.00000000002'.split(".")[1].length)//11
  console.log(d+2)//2.00000000002
  console.log(d+0.00000000002)//4e-11

我们可以看到初始定义的number类型的d在打印的时间直接打印的是科学计数法显示的数据

通过4,5行的js可以看出科学计数法的显示是不影响的计算的。

但是我们在前端页面的渲染的时间很多情况下,是不能显示为科学计数法的,比如比特币的成交额,有些价值很高的币,在交易的过程中会出现科学计数法的情况,但是我们去渲染的时间,是不能显示为科学计数法的,所以就要对科学计数法的数据进行处理。

三,通过封装的函数解决

function toolNumber(num_str) {
        num_str = num_str.toString();
        if (num_str.indexOf("+") != -1) {
          num_str = num_str.replace("+", "");
        }
        if (num_str.indexOf("E") != -1 || num_str.indexOf("e") != -1) {
          var resValue = "",
            power = "",
            result = null,
            dotIndex = 0,
            resArr = [],
            sym = "";
          var numStr = num_str.toString();
          if (numStr[0] == "-") {
            // 如果为负数,转成正数处理,先去掉‘-’号,并保存‘-’.
            numStr = numStr.substr(1);
            sym = "-";
          }
          if (numStr.indexOf("E") != -1 || numStr.indexOf("e") != -1) {
            var regExp = new RegExp(
              "^(((\\d+.?\\d+)|(\\d+))[Ee]{1}((-(\\d+))|(\\d+)))$",
              "ig"
            );
            result = regExp.exec(numStr);
            if (result != null) {
              resValue = result[2];
              power = result[5];
              result = null;
            }
            if (!resValue && !power) {
              return false;
            }
            dotIndex = resValue.indexOf(".") == -1 ? 0 : resValue.indexOf(".");
            resValue = resValue.replace(".", "");
            resArr = resValue.split("");
            if (Number(power) >= 0) {
              var subres = resValue.substr(dotIndex);
              power = Number(power);
              //幂数大于小数点后面的数字位数时,后面加0
              for (var i = 0; i <= power - subres.length; i++) {
                resArr.push("0");
              }
              if (power - subres.length < 0) {
                resArr.splice(dotIndex + power, 0, ".");
              }
            } else {
              power = power.replace("-", "");
              power = Number(power);
              //幂数大于等于 小数点的index位置, 前面加0
              for (var i = 0; i < power - dotIndex; i++) {
                resArr.unshift("0");
              }
              var n = power - dotIndex >= 0 ? 1 : -(power - dotIndex);
              resArr.splice(n, 0, ".");
            }
          }
          resValue = resArr.join("");

          return sym + resValue;
        } else {
          return num_str;
        }
      }

示例:



var d=0.00000000002;
console.log(d);//2e-11
console.log('0.00000000002'.length)//13
console.log('0.00000000002'.split(".")[1].length)//11
console.log(d+2)//2.00000000002
console.log(d+0.00000000002)//4e-11




var a=0.000000009;
console.log('0.000000009')//0.000000009
console.log(a)//9e-9
console.log(toolNumber(a))//0.000000009




var b=10000000000000000000000;

console.log('10000000000000000000000')//10000000000000000000000
console.log('10000000000000000000000'.length)//23
console.log(b);//1e+22
console.log(toolNumber(b))//10000000000000000000000
console.log(toolNumber(b).length)//23

上一篇:【vue】项目启动命令的配置与切换


下一篇:【k线】k线图中MA均线计算