JS保留两位小数的函数有哪些

 4044

js保留两位小数函数有:1、【toFixed()】函数;2、【Math.floor()】函数不四舍五入 ,向下取整;3、使用字符串匹配方法;4、四舍五入保留2位小数;5、浮点数保留两位小数。


JS保留两位小数的函数有哪些


js保留两位小数的函数有:

一、四舍五入相关

1、toFixed()方法

需注意,保留两位小数,将数值类型的数据改变成了字符串类型

  1. // 1.四舍五入
  2. var num =2.446242342; 
  3. num = num.toFixed(2); 
  4. console.log(num); //2.45
  5. console.log(typeof num); // string

2、Math.floor(),不四舍五入 ,向下取整

注意,不改变数据类型

  1. // 2.不四舍五入 向下取整
  2. num = Math.floor(num * 100) / 100;
  3. console.log(num); //2.44
  4. console.log(typeof num); // number

3、字符串匹配

注意,先将数据转换为字符串,最后再转为数值类型

  1. // 3.不四舍五入 字符串匹配再转换
  2. num = Number(num.toString().match(/^\d+(?:\.\d{0,2})?/));
  3. console.log(num); //2.44
  4. console.log(typeof num); // number

4、四舍五入保留2位小数(若第二位小数为0,则保留一位小数)

注意,数据类型不变

  1. //4.四舍五入保留2位小数(若第二位小数为0,则保留一位小数)
  2. function keepTwoDecimal(num) {
  3.     var result = parseFloat(num);
  4.     if (isNaN(result)) {
  5.         alert('传递参数错误,请检查!');
  6.         return false;
  7.     }
  8.     result = Math.round(num * 100) / 100;
  9.     return result;
  10. };
  11. keepTwoDecimal(num);
  12. console.log(num); //2.44
  13. console.log(typeof num); //number

5、四舍五入保留2位小数(不够位数,则用0替补)

注意,数据类型变为字符串类型

  1. //5.四舍五入保留2位小数(不够位数,则用0替补)
  2. function keepTwoDecimalFull(num) {
  3.     var result = parseFloat(num);
  4.     if (isNaN(result)) {
  5.         alert('传递参数错误,请检查!');
  6.         return false;
  7.     }
  8.     result = Math.round(num * 100) / 100;
  9.     var s_x = result.toString(); //将数字转换为字符串
  10.     var pos_decimal = s_x.indexOf('.'); //小数点的索引值
  11.     // 当整数时,pos_decimal=-1 自动补0
  12.     if (pos_decimal < 0) {
  13.         pos_decimal = s_x.length;
  14.         s_x += '.';
  15.     }
  16.     // 当数字的长度< 小数点索引+2时,补0
  17.     while (s_x.length <= pos_decimal + 2) {
  18.         s_x += '0';
  19.     }
  20.     return s_x;
  21. }
  22. console.log(keepTwoDecimalFull(120.5)); //120.50
  23. console.log(typeof keepTwoDecimalFull(120.5)); //string
  24. console.log(keepTwoDecimalFull(2.446242342)); //2.45
  25. console.log(typeof keepTwoDecimalFull(2.446242342)); //string

二、浮点数保留两位小数

1、将浮点数四舍五入,取小数点后2位

注意,数据类型不变

  1. //浮点数保留两位小数
  2. //1.功能:将浮点数四舍五入,取小数点后2位
  3. function toDecimal(x) {
  4.     var f = parseFloat(x);
  5.     if (isNaN(f)) {
  6.         return;
  7.     }
  8.     f = Math.round(x*100)/100;
  9.     return f;
  10. }
  11. console.log(toDecimal(3.1465926)); // 3.15
  12. console.log(typeof toDecimal(3.1415926)); //number

2、强制保留2位小数,如:2,会在2后面补上00.即2.00

注意,数据类型变为字符串类型

  1. //2.强制保留2位小数,如:2,会在2后面补上00.即2.00
  2. function toDecimal2(x) {
  3.     var f = parseFloat(x);
  4.     if (isNaN(f)) {
  5.         return false;
  6.     }
  7.     var f = Math.round(x*100)/100;
  8.     var s = f.toString();
  9.     var rs = s.indexOf('.');
  10.     if (rs < 0) {
  11.         rs = s.length;
  12.         s += '.';
  13.     }
  14.     while (s.length <= rs + 2) {
  15.         s += '0';
  16.     }
  17.     return s;
  18. }
  19. console.log(toDecimal2(3.1)); // 3.10
  20. console.log(typeof toDecimal2(3.1415926)); //string

3、保留两位小数 浮点数四舍五入 位数不够 不补0

注意,数据类型不变

  1. // 3.保留两位小数 浮点数四舍五入 位数不够 不补0
  2. function fomatFloat(src,pos){
  3.     return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos);
  4. }
  5. console.log(fomatFloat(3.12645,2)); // 3.13
  6. console.log(typeof fomatFloat(3.1415926)); //numbe




TAG标签:
本文网址:https://www.zztuku.com/index.php/detail-7948.html
站长图库 - JS保留两位小数的函数有哪些
申明:如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐