Javascript的數學難題

首先先考大家幾個數學題,如果這幾題的答案你都能順利的回答,那恭喜你!你可以安心地閱讀這篇文章,你一定能看懂!

題目ㄧ. 0.1 + 0.2 = ?
題目二. 1 – 0.9 = ?
題目三. 0.69 x 10 = ?

相信上面三個簡單的十進位數學運算,你的答案應該會跟我一樣吧?

第一題. 0.3
第二題. 0.1
第三題. 6.9

上面應該是無庸置疑的答案,但是如果我們把這三個題目丟給Javascript去運算之後,得到的結果會變成這樣:

第一題. 0.1 + 0.2 = 0.30000000000000004
第二題. 1 – 0.9 = 0.09999999999999998
第三題. 0.69 x 10 = 6.8999999999999995

什麼!?Javascript連這種小學生的算術都會算錯嗎?其實是有原因的,Javascript所有數字都是以64位浮點數形式儲存,也就是所有的數字都會變轉換成二進位。

上面題目中特別有提到這是3個十進位的數學運算,這也就是這個題目的重點,如果今天的題目改成:10 / 3 = 3.3333333333333334 也許你就能比較明白了,也就是說在十進位中要表達 1 / 3 和二進位中表達 1 / 10 一樣困難。

但其實在我們設計網頁的過程中,使用者是沒有二進位觀念的,只在乎運算出來的數值是否符合十進位的結果,這個時候我們可以利用一些技巧來達成正確的結果。

方法1 . 將小數變成整數後再進行運算


第一題. ((0.1 x 10) + (0.2 x 10)) / 10 = 0.3
第二題. ((1 x 10) – (0.9 x 10)) / 10 = 0.1
第三題. ((0.69 x 100) x 10 / 100) = 6.9

雖說以上的方法能夠順利完成任務,但若運算的數值是動態(Dynamic)的,乘數的部分就比較難下,所以我們可以採用第二種方法。

方法2. Math.js(https://mathjs.org/


透過網站上提供的js,或是透過CDN(https://cdnjs.com/libraries/mathjs)來引入後,透過以下的方法,就可以正確計算出上面三個題目的結果,其中14指的是精準度,通常已經很夠用了。

第一題. math.format(0.1 + 0.2 , 14) = 0.3
第一題. math.format(1 – 0.9 , 14) = 0.1
第一題. math.format(0.69 x 10 , 14) = 6.9

其實Math.js還有很多好用的功能,可以到它官方的網站閱讀一些文章,基本上所有的數學運算應該都可以透過它來玩完成。

You may also like...

110,053 Responses

  1. Leonardret表示:

    надежный маркетплейс блэкспрут где сочетаются безопасность, широкий выбор товаров и удобство использования. Платформа работает с анонимными платежами и гарантирует полную конфиденциальность для всех пользователей.

  2. Normankem表示:

    рыбалка на частных территориях рыбалка на волге осенью

  3. LarryLog表示:

    semaglutide best price: generic rybelsus tabs – buy rybelsus online

  4. AlbertNer表示:

    https://kamapharm.shop/# Kama Pharm
    prednisone generic cost

  5. Nasosy_xlPl表示:

    насос для отопления https://nasosy-msk.ru/ .

  6. Dannyfut表示:

    darkweb marketplace deep web links dark web site

  7. Dannyfut表示:

    deep web drug store darknet drug links dark web link

  8. Aileen206表示:

    Amazing knowledge and I like to share this kind of information with my friends and hope they like it they why I do

  9. Waltererync表示:

    buy Kamagra: Kama Pharm – Kama Pharm

  10. Brianlit表示:

    priligy Priligy tablets buy priligy

  11. Dannyfut表示:

    tor market dark market 2025 darkmarket 2025

  12. Nasosy_cqPl表示:

    насос циркуляционный насос циркуляционный .

  13. Dannyfut表示:

    darknet seiten darkweb marketplace tor market links

  14. Nasosy_ecPl表示:

    насос для скважины https://nasosy-msk.ru/ .

  15. Nasosy_biPl表示:

    купить глубинный насос купить глубинный насос .

  16. DanielZek表示:

    https://kamapharm.com/# Kama Pharm
    Kamagra Oral Jelly

  17. AlbertNer表示:

    https://predpharm.shop/# prednisone 10 mg over the counter
    5 mg prednisone tablets

  18. In that case, the federal government can default, or attempt to shift to an export-led strategy or increase curiosity charges to draw foreign investment in the forex.

  19. kypit 1s_yoEa表示:

    программа 1с бухгалтерия купить в москве программа 1с бухгалтерия купить в москве .

  20. вывод из запоя круглосуточно ростов на дону вывод из запоя круглосуточно ростов на дону .

  21. AlbertNer表示:

    https://cytpharm.shop/# CytPharm
    prednisone tablets 2.5 mg

  22. 都市の星表示:

    This debt snowball methodology tracker is easy to use and will assist you stay organized along with your debt funds for quicker debt repayment so you’ll be able to obtain financial freedom.

  23. Dannyfut表示:

    darknet search engine darkmarket url dark market url

  24. LarryLog表示:

    Pred Pharm: Pred Pharm – Pred Pharm

  25. kypit 1s_faEa表示:

    программы фирмы 1с программы фирмы 1с .

  26. Dannyfut表示:

    dark market url dark websites darkmarket link

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。