//正確な除算結果を取得するために使用される除算関数
//説明: JavaScript の除算結果にはエラーが含まれます。これは、2 つの浮動小数点数を除算するときにより顕著になります。この関数は、より正確な除算結果を返します。
//呼び出し: accp(arg1,arg2)
//戻り値: arg1 を arg2 で除算した正確な結果
function accp(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); } }
//呼び出しをより便利にするために、p メソッドを Number 型に追加します。
Number.prototype.p = function (arg){
Return accp(this, arg);
}
//正確な乗算結果を取得するために使用される乗算関数
//説明: JavaScript の乗算結果にはエラーが発生します。 2 つの浮動小数点数を乗算すると、より明らかになります。この関数は、より正確な乗算結果を返します。
//呼び出し: accMul(arg1,arg2)
//戻り値: arg1 と arg2 を乗算した正確な結果
function accMul(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); }
//呼び出しをより便利にするために、Number 型に mul メソッドを追加します。
Number.prototype.mul = function (arg){ return accMul(arg, this); };
//正確な加算結果を取得するために使用される加算関数
//説明: JavaScript の加算結果にはエラーが含まれます。これは、2 つの浮動小数点数を加算するときにより明白になります。この関数は、より正確な加算結果を返します。
//呼び出し: accAdd(arg1,arg2)
//戻り値: arg1 と arg2 の正確な結果
function accAdd(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; }
//给Number类型增加一个add方法,调用起来更加方便。 Number.prototype.add = function (arg){ return accAdd(arg,this); } //减法函数 function accSub(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)); //last modify by deeka //动态控制精度长度 n=(r1>=r2)?r1:r2; return ((arg2*m-arg1*m)/m).toFixed(n); } ///给number类增加一个sub方法,调用起来更加方便 Number.prototype.sub = function (arg){ return accSub(arg,this); }
以上がJS浮動小数点数の正確な計算の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。