js常用小方法,浮点数的计算等

var trimNumber = function(number) {


        // 按实际的小数位显示, 最多两位小数.


        // 1.23=1.23, 1.20=1.2, 1.00=1


        if (number.toFixed(1)*1 != number.toFixed(2)*1) {


            return number.toFixed(2);


        } else if (number.toFixed(0)*1 != number.toFixed(1)*1) {


            return number.toFixed(1);


        } else {


            return number.toFixed(0);


        }


    };

// 去重   oArr nArr  map
var nArr = [];
var map ;
for(var i in oArr){
map.put(oArr[i].FIELD_DS7.split('-')[0],oArr[i].FIELD_DS7);
if(!map.get((oArr[i].FIELD_DS7.split('-')[0])){
nArr.push(oArr[i])
}
}




//  排序[] -- [{}]类型根据某个attr排序
function compare(attr){
    return function(a,b){
        var v1 = a[attr];
        var v2 = b[attr];
        return v1 - v2;
    }
}


//浮点数加法运算   
 function FloatAdd(arg1,arg2){   
   var r1,r2,m;   
   try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}   
   try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}   
   m=Math.pow(10,Math.max(r1,r2))   
   return (arg1*m+arg2*m)/m   
  }   
  
 //浮点数减法运算   
 function FloatSub(arg1,arg2){   
 var r1,r2,m,n;   
 try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}   
 try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}   
 m=Math.pow(10,Math.max(r1,r2));   
 //动态控制精度长度   
 n=(r1>=r2)?r1:r2;   
 return ((arg1*m-arg2*m)/m).toFixed(n);   
 }   
    
 //浮点数乘法运算   
 function FloatMul(arg1,arg2)    
 {    
  var m=0,s1=arg1.toString(),s2=arg2.toString();    
  try{m+=s1.split(".")[1].length}catch(e){}    
  try{m+=s2.split(".")[1].length}catch(e){}    
  return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m)    
  }    
  
  
//浮点数除法运算   
function FloatDiv(arg1,arg2){    
var t1=0,t2=0,r1,r2;    
try{t1=arg1.toString().split(".")[1].length}catch(e){}    
try{t2=arg2.toString().split(".")[1].length}catch(e){}    
with(Math){    
r1=Number(arg1.toString().replace(".",""))    
r2=Number(arg2.toString().replace(".",""))    
return (r1/r2)*pow(10,t2-t1);    
}    
}   
但是以上方法仍然不能完好的控制精度,还得需要保留小数位数的方法控制,于是改写了某位大人的方法
 function to2bits(flt,pos) {
  var rd=1;  
  for(var i=1;i<=parseInt(pos);i++)
  {
   rd=rd*10;
  }
 if(parseFloat(flt) == flt)
   return Math.round(flt * rd) / rd;
 else
  return 0;
 }
将两个方法结合起来基本上能获得满意的效果,例如,加法运算变成
//浮点数加法运算   
 function FloatAdd(arg1,arg2){   
   var r1,r2,m;   
   try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}   
   try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}   
   m=Math.pow(10,Math.max(r1,r2))   
   return to2bits((arg1*m+arg2*m)/m,2);   
  }
以上结果保留两位小数:)其它的大家自己试试吧







调用的例子:
        var centerLng = FloatDiv((FloatAdd(a,b)),2);    
//(a+b)/2


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值