js保留两位⼩数⽅法总结
本⽂是⼩编针对js保留两位⼩数这个⼤家经常遇到的经典问题整理了在各种情况下的函数写法以及遇到问题的分析,以下是全部内容:
⼀、我们⾸先从经典的“四舍五⼊”算法讲起
1、四舍五⼊的情况
var num =2.446242342;
num = Fixed(2); // 输出结果为 2.45
2、不四舍五⼊
第⼀种,先把⼩数边整数:
Math.floor(15.7784514000 * 100) / 100 // 输出结果为 15.77
第⼆种,当作字符串,使⽤正则匹配:
Number(String().match(/^\d+(?:\.\d{0,2})?/)) // 输出结果为 15.77,不能⽤于整数如 10 必须写为10.0000
注意:如果是负数,请先转换为正数再计算,最后转回负数
再分享⼀个经典的解决四舍五⼊问题后js保留两位⼩数的⽅法:
//四舍五⼊保留2位⼩数(若第⼆位⼩数为0,则保留⼀位⼩数)
function keepTwoDecimal(num) {
var result = parseFloat(num);
if (isNaN(result)) {
alert('传递参数错误,请检查!');
return false;
}
result = und(num * 100) / 100;
return result;
}
四舍五入函数保留整数//四舍五⼊保留2位⼩数(不够位数,则⽤0替补)
function keepTwoDecimalFull(num) {
var result = parseFloat(num);
if (isNaN(result)) {
alert('传递参数错误,请检查!');
return false;
}
result = und(num * 100) / 100;
var s_x = String();
var pos_decimal = s_x.indexOf('.');
if (pos_decimal < 0) {
pos_decimal = s_x.length;
s_x += '.';
}
while (s_x.length <= pos_decimal + 2) {
s_x += '0';
}
return s_x;
}
如果⼤家想对javascript有系统深⼊的学习,可以参阅这本经典书籍
⼆、Js取float型⼩数点后两位数的⽅法
<script type="text/javascript">
//保留两位⼩数
//功能:将浮点数四舍五⼊,取⼩数点后2位
function toDecimal(x) {
var f = parseFloat(x);
if (isNaN(f)) {
return;
}
f = und(x*100)/100;
return f;
}
//制保留2位⼩数,如:2,会在2后⾯补上00.即2.00
function toDecimal2(x) {
var f = parseFloat(x);
if (isNaN(f)) {
return false;
}
var f = und(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;
}
function fomatFloat(src,pos){
und(src*Math.pow(10, pos))/Math.pow(10, pos);
}
/
/四舍五⼊
alert("保留2位⼩数:" + toDecimal(3.14159267));
alert("强制保留2位⼩数:" + toDecimal2(3.14159267));
alert("保留2位⼩数:" + toDecimal(3.14559267));
alert("强制保留2位⼩数:" + toDecimal2(3.15159267));
alert("保留2位⼩数:" + fomatFloat(3.14559267, 2));
alert("保留1位⼩数:" + fomatFloat(3.15159267, 1));
//五舍六⼊
alert("保留2位⼩数:" + Fixed(2));
alert("保留1位⼩数:" + Fixed(1));
alert("保留1位⼩数:" + Fixed(1));
alert("保留1位⼩数:" + Fixed(1));
//科学计数
alert(Exponential(2));
alert(Exponential(2));
alert(Exponential(2));
alert(Exponential(2));
alert(Exponential(1));
//精确到n位,不含n位
alert("精确到⼩数点第2位" + Precision(2));
alert("精确到⼩数点第3位" + Precision(3));
alert("精确到⼩数点第2位" + Precision(2));
alert("精确到⼩数点第2位" + Precision(2));
alert("精确到⼩数点第5位" + Precision(5));
</script>
⽤Javascript取float型⼩数点后两位,例22.127456取成22.13,如何做?
1.丢弃⼩数部分,保留整数部分
parseInt(5/2)
2.向上取整,有⼩数就整数部分加1
3,四舍五⼊.
4,向下取整
Math.floor(5/2)
另类的⽅法
1. 最笨的办法
function get()
{
var s = 22.127456 + "";
var str = s.substring(0,s.indexOf(".") + 3);
alert(str);
}
2. 正则表达式效果不错
<script type="text/javascript">
onload = function(){
var a = "23.456322";
var aNew;
var re = /([0-9]+.[0-9]{2})[0-9]*/;
aNew = a.replace(re,"$1");
alert(aNew);
}
</script>
3. 他就⽐较聪明了
<script>
var num=22.127456;
alert( und(num*100)/100);
</script>
4.会⽤新鲜东西的朋友....... 但是需要 IE
5.5+才⽀持。
5.js保留2位⼩数(强制)
对于⼩数点位数⼤于2位的,⽤上⾯的函数没问题,但是如果⼩于2位的,⽐如:changeTwoDecimal(3.1),将返回3.1,如果你⼀定需要3.10这样的格式,那么需要下⾯的这个函数:
function changeTwoDecimal_f(x) {
var f_x = parseFloat(x);
if (isNaN(f_x)) {
alert('function:changeTwoDecimal->parameter error');
return false;
}
var f_x = und(x * 100) / 100;
var s_x = String();
var pos_decimal = s_x.indexOf('.');
if (pos_decimal < 0) {
pos_decimal = s_x.length;
s_x += '.';
}
while (s_x.length <= pos_decimal + 2) {
s_x += '0';
}
return s_x;
}
三、js保留两位⼩数,⾃动补充零
function returnFloat(value){
var und(parseFloat(value)*100)/100;
var String().split(".");
if(xsd.length==1){
String()+".00";
return value;
}
if(xsd.length>1){
if(xsd[1].length<2){
String()+"0";
}
return value;
}
}
四、JS取整数,js取绝对值,js四舍五⼊(可保留两位⼩数)
JS取整数,js取绝对值,js四舍五⼊(可保留两位⼩数)函数如下:
<SCRIPT language=javascript>
<!--
function jsMath()
{
document.write(Math.floor(5.80) + "<br>");//取整或下舍⼊
document.und(5.80) + "<br>");//四舍五⼊,取整数
document.und((5.80*100)/100) + "<br>");//四舍五⼊,保留两位⼩数
document.il(5.10) + "<br>");//上舍⼊
document.write(Math.abs(-5.80) + "<br>");//取绝对值
document.write(Math.max(55,58) + "<br>");//返回两个值中最⼤数
document.write(Math.min(55,58) + "<br>");//返回两个值中最⼩数
}
-->
</SCRIPT>
<div>
<script>jsMath();</script>
</div>
总结
JS数据格式化是在进⾏web前端开发时常碰到的事情,特别是在数据类型为Float的数据就需要特殊处理,如保留两位⼩数、⼩数点后的数据是否需要四舍五⼊等等。下⾯就来介绍实现数据格式化保留两位⼩数的多种⽅法。
1、JS⾃带的⽅法toFixed(),toFixed() ⽅法可把 Number 四舍五⼊为指定⼩数位数的数字。
语法:Fixed(num),mun是必需的参数,即规定⼩数的位数,是 0 ~ 20 之间的值,包括 0 和 20,有些实现可以⽀持更⼤的数值范围。如果省略了该参数,将⽤ 0 代替,所以toFixed() ⽅法可以实现保留2位、3位、4位等等,取决于num的数值。
返回值:返回 NumberObject 的字符串表⽰,不采⽤指数计数法,⼩数点后有固定的 num 位数字。如果必要,该数字会被舍⼊,也可以⽤ 0 补⾜,以便它达到指定的长度。如果 num ⼤于 le+21,则该⽅法只调⽤ String(),返回采⽤指数计数法表⽰的字符串。
当 num 太⼩或太⼤时抛出异常 RangeError。0 ~ 20 之间的值不会引发该异常。有些实现⽀持更⼤范围或更⼩范围内的值。
当调⽤该⽅法的对象不是 Number 时抛出 TypeError 异常。
<script type=”text/javascript”>
var num = new Number(13.376954);
document.write (Fixed(2))
</script>
输出:13.38
2、⾃定义函数实现⼩数保留并四舍五⼊。
function roundFun(numberRound,roundDigit) { //四舍五⼊,保留位数为roundDigit
if (numberRound>=0){
var tempNumber = parseInt((numberRound * Math.pow(10,roundDigit)+0.5))/Math.pow(10,roundDigit);
return tempNumber;
} else{
numberRound1=-numberRound;
var tempNumber = parseInt((numberRound1 * Math.pow(10,roundDigit)+0.5))/Math.pow(10,roundDigit);
return -tempNumber;
}
}
然后调⽤roundFun()这个函数就可以了。如roundFun('13.376954′,2);当然返回的结果跟第⼀种⽅法是⼀样的。
3、通过函数截取,截取到⼩数点后⾯第⼏位,当然这种⽅法就没有四舍五⼊了。
<script type=”text/javascript”>
tmp = 13.376954″
result = tmp.substr(0,tmp.indexOf(“.”)+2);
alert(result);
</script>
以上就是⼩编为⼤家整理的关于js保留两位⼩数⽅法的总结内容,感谢你的⽀持,如果你对js保留两位⼩数⽅法还有任何不明⽩的地⽅,可以在下⽅的留⾔区讨论。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论