上一篇的js处理失真数据存在问题换了种方法
1.加法方式
function numAdd(num1: number, num2: number): number{
let baseNum: number, baseNum1: number, baseNum2: number;
try {
baseNum1 = num1.toString().split(".")[1].length;
} catch (e) {
baseNum1 = 0;
}
try {
baseNum2 = num2.toString().split(".")[1].length;
} catch (e) {
baseNum2 = 0;
}
baseNum = Math.pow(10, Math.max(baseNum1, baseNum2));
return (num1 * baseNum + num2 * baseNum) / baseNum;
};
2.減法方式
/**
* @param num1被減數
* @param num2減數
*/
function numSub(num1: number, num2: number): number{
let baseNum: number, baseNum1: number, baseNum2: number;
try {
baseNum1 = num1.toString().split(".")[1].length;
} catch (e) {
baseNum1 = 0;
}
try {
baseNum2 = num2.toString().split(".")[1].length;
} catch (e) {
baseNum2 = 0;
}
baseNum = Math.pow(10, Math.max(baseNum1, baseNum2));
return (num1 * baseNum - num2 * baseNum) / baseNum;
};
?
例如:numAdd1(283.34,141.67);
function accAddOwn(one,two ,str){
//轉化為字符串
one = ''+one
two = ''+two
str = '+'
//切割成整數部分和小數部分
var oneStr = one.split('.')
var twoStr = two.split('.')
// 處理參數一或二為整數的情況
if(!oneStr[1]){
oneStr[1] = ''
}
if(!twoStr[1]){
twoStr[1] = ''
}
var length=null
//比較小數部分的長度,以確定剝離小數點后放大的倍數
var oneFloatLength = oneStr[1].length
var TwoFloatLength = twoStr[1].length
if(oneFloatLength>TwoFloatLength){
length = oneFloatLength
twoStr[1]=twoStr[1].padEnd(length,'0')
} else if(TwoFloatLength>oneFloatLength){
length = TwoFloatLength
twoStr[1]=oneStr[1].padEnd(length,'0')
} else{
length = TwoFloatLength
}
// 拼接成處理后的數字
var oneBig = oneStr[0]+oneStr[1]
var twoBig = twoStr[0]+twoStr[1]
//根據運算符決定運算后縮小的倍數
var result= null
switch(str){
case '+' :;
case '-' : result = eval(oneBig+str+twoBig)/(10**length)
break;
case '*' : result = eval(oneBig+str+twoBig)/(10**(length*2))
break;
case '/' : result = eval(oneBig+str+twoBig)
}
return result; }
還是用decimal.js吧
npm install --save decimal.js
?
// 加法
?
new Decimal(a).add(new Decimal(b))?
?
// 減法
?
new Decimal(a).sub(new Decimal(b))
?
// 乘法
?
new Decimal(a).mul(new Decimal(b))
?
// 除法
?
new Decimal(a).div(new Decimal(b))
?
轉載于:https://www.cnblogs.com/hr-cmbc/p/11332228.html
總結
以上是生活随笔為你收集整理的上一篇的js处理失真数据存在问题换了种方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: HDU 2084 数塔(DP)(JAVA
- 下一篇: nginx环境的搭建