精华内容
下载资源
问答
  • js保留两位小数方法

    千次阅读 2020-08-19 16:26:59
    js保留两位小数方法 1、四舍五入的情况 var num =2.446242342; num = num.toFixed(2); // 输出结果为 2.45 2、不四舍五入 1.第一种,先把小数边整数: 1.丢弃小数部分,保留整数部分 parseInt(5/2) 2.向上取整,有...

    js保留两位小数方法

    1、四舍五入的情况

    var num =2.446242342;
    num = num.toFixed(2); // 输出结果为 2.45
    

    2、不四舍五入

    1.第一种,先把小数边整数:

    1.丢弃小数部分,保留整数部分
    parseInt(5/2)
    
    2.向上取整,有小数就整数部分加1
    Math.ceil(5/2)
    
    3,四舍五入.
    Math.round(5/2)
    
    4,向下取整
    Math.floor(5/2)
    Math.floor(15.7784514000 * 100) / 100 // 输出结果为 15.77
    

    2.第二种,当作字符串,使用正则匹配:

    Number(15.7784514000.toString().match(/^\d+(?:\.\d{0,2})?/)) // 输出结果为 15.77,不能用于整数如 10 必须写为10.0000
    

    注意:如果是负数,请先转换为正数再计算,最后转回负数

    展开全文
  • 本篇文章给大家总结了js保留两位小数的各种方法以及每种方法的实例代码分析,如果大家对此有需要,一起来学习下js保留两位小数方法吧。
  • 问题是,当用户离开文本框时,我需要将用户输入的内容转换成保留两位小数的格式,然后我试了toFixed()方法,这个方法也不可行,因为它将数据转换成了字符串,传给后台是错的 JavaScripttoFixed()方法 把数字转换...

    经常需要用到金额保留两位小数,刚开始用的是Angular中的过滤器number | 2,但是,这无法满足我的需求。问题是,当用户离开文本框时,我需要将用户输入的内容转换成保留两位小数的格式,然后我试了toFixed()方法,这个方法也不可行,因为它将数据转换成了字符串,传给后台是错的

    JavaScript toFixed() 方法

    把数字转换为字符串,结果的小数点后有指定位数的数字

    var num = 5.56789;
    var n=num.toFixed(2);//5.57

    一、四舍五入相关

    toFixed()方法

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

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

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

    注意,不改变数据类型

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

    字符串匹配

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

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

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

    注意,数据类型不变

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

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

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

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

    二、浮点数保留两位小数

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

    注意,数据类型不变

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

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

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

    //2.强制保留2位小数,如:2,会在2后面补上00.即2.00
    function toDecimal2(x) {
    var f = parseFloat(x);
    if (isNaN(f)) {
    	return false;
    }
    var f = Math.round(x*100)/100;
    var s = f.toString();
    var rs = s.indexOf('.');
    if (rs < 0) {
    	rs = s.length;
    	s += '.';
    }
    while (s.length <= rs + 2) {
    	s += '0';
    }
    	return s;
    }
    console.log(toDecimal2(3.1)); // 3.10
    console.log(typeof toDecimal2(3.1415926)); //string

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

    注意,数据类型不变

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

     

    展开全文

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 15,964
精华内容 6,385
关键字:

js保留两位小数的方法