欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js計算精度問題小結(jié)

 更新時間:2013年04月22日 14:56:04   作者:  
js計算精度問題小結(jié),需要的朋友可以參考一下

復(fù)制代碼 代碼如下:

//問題比如:7*0.8 JavaScript算出來就是:5.6000000000000005

            //加法函數(shù),用來得到精確的加法結(jié)果
            //說明:javascript的加法結(jié)果會有誤差,在兩個浮點(diǎn)數(shù)相加的時候會比較明顯。這個函數(shù)返回較為精確的加法結(jié)果。
            //調(diào)用:accAdd(arg1,arg2)
            //返回值:arg1加上arg2的精確結(jié)果
            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方法,調(diào)用起來更加方便。
            Number.prototype.add = function (arg) {
                return accAdd(arg, this);
            }
            //如:
            var t1 = 6.60;
            var t2 = 1.32;
            var t3 = 1.2;
            var t4 = 1.2;
            var t5 = 1.2;
            alert(Number(t1).add(Number(t2)).add(Number(t3)).add(Number(t4)).add(Number(t5)));

            //減法函數(shù),用來得到精確的減法結(jié)果
            function Subtr(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
                //動態(tài)控制精度長度
                n = (r1 >= r2) ? r1 : r2;
                return ((arg1 * m - arg2 * m) / m).toFixed(n);
            }

            //乘法函數(shù),用來得到精確的乘法結(jié)果
            //說明:javascript的乘法結(jié)果會有誤差,在兩個浮點(diǎn)數(shù)相乘的時候會比較明顯。這個函數(shù)返回較為精確的乘法結(jié)果。
            //調(diào)用:accMul(arg1,arg2)
            //返回值:arg1乘以arg2的精確結(jié)果
            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方法,調(diào)用起來更加方便。
            Number.prototype.mul = function (arg) {
                return accMul(arg, this);
            }

            //除法函數(shù),用來得到精確的除法結(jié)果
            //說明:javascript的除法結(jié)果會有誤差,在兩個浮點(diǎn)數(shù)相除的時候會比較明顯。這個函數(shù)返回較為精確的除法結(jié)果。
            //調(diào)用:accDiv(arg1,arg2)
            //返回值:arg1除以arg2的精確結(jié)果
            function accDiv(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);
                }
            }
            //用法:
            //給Number類型增加一個div方法,調(diào)用起來更加方便。

相關(guān)文章

  • JS定時刷新頁面及跳轉(zhuǎn)頁面的方法

    JS定時刷新頁面及跳轉(zhuǎn)頁面的方法

    這篇文章介紹了JS定時刷新頁面及跳轉(zhuǎn)頁面的方法,有需要的朋友可以參考一下
    2013-07-07
  • 詳談js中數(shù)組(array)和對象(object)的區(qū)別

    詳談js中數(shù)組(array)和對象(object)的區(qū)別

    下面小編就為大家?guī)硪黄斦刯s中數(shù)組(array)和對象(object)的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • JavaScript中this的四個綁定規(guī)則總結(jié)

    JavaScript中this的四個綁定規(guī)則總結(jié)

    相信大家都知道,ES5及之前時代的JavaScript中this的綁定機(jī)制是讓很多開發(fā)者頭疼不已的事情。this 的綁定變化多端,讓筆者也吃了不少虧。所以本文總結(jié)了this的四條綁定規(guī)則,在此記錄,以防自己遺忘,也方便他人參考借鑒。下面來一起看看吧。
    2016-09-09
  • JS正則表達(dá)式之非捕獲分組用法實(shí)例分析

    JS正則表達(dá)式之非捕獲分組用法實(shí)例分析

    這篇文章主要介紹了JS正則表達(dá)式之非捕獲分組用法,結(jié)合實(shí)例形式詳細(xì)分析了正則表達(dá)式中非捕獲分組的概念、功能、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2016-12-12
  • javascript事件模型實(shí)例分析

    javascript事件模型實(shí)例分析

    這篇文章主要介紹了javascript事件模型用法,實(shí)例分析了事件模型、事件對象、事件監(jiān)聽器及事件傳遞的定義與使用技巧,需要的朋友可以參考下
    2015-01-01
  • 一些常用的Javascript函數(shù)

    一些常用的Javascript函數(shù)

    一些常用的Javascript函數(shù)...
    2006-12-12
  • 通過正則格式化url查詢字符串實(shí)現(xiàn)代碼

    通過正則格式化url查詢字符串實(shí)現(xiàn)代碼

    看到項(xiàng)目里通過js數(shù)組split方法格式化查詢字符串的,突發(fā)奇想為什么不能用正則呢,性能如何?感興趣的朋友可以研究下哦
    2012-12-12
  • javascript獲取ckeditor編輯器的值(實(shí)現(xiàn)代碼)

    javascript獲取ckeditor編輯器的值(實(shí)現(xiàn)代碼)

    這篇文章主要介紹了javascript獲取ckeditor編輯器的值,用于表單驗(yàn)證。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-11-11
  • JavaScript哪些場景不能使用箭頭函數(shù)

    JavaScript哪些場景不能使用箭頭函數(shù)

    這篇文章主要介紹了JavaScript哪些場景不能使用箭頭函數(shù),幫助大家更好的理解和學(xué)習(xí)使用JavaScript,感興趣的朋友可以了解下
    2021-04-04
  • 如何基于JS實(shí)現(xiàn)Ajax并發(fā)請求的控制詳解

    如何基于JS實(shí)現(xiàn)Ajax并發(fā)請求的控制詳解

    通常為了減少頁面加載時間,先把核心內(nèi)容顯示處理,頁面加載完成后再發(fā)送ajax請求獲取其他數(shù)據(jù),這時就可能產(chǎn)生多個ajax請求,為了用戶體驗(yàn),最好是發(fā)送并行請求,這篇文章主要給大家介紹了關(guān)于如何基于JS實(shí)現(xiàn)Ajax并發(fā)請求控制的相關(guān)文章,需要的朋友可以參考下
    2021-08-08

最新評論