點擊藍字 ╳ 關注我們
特點
使用場景
使用示例
1.安裝bignumber.js
ohpminstallbignumber.js
OpenHarmony ohpm環(huán)境配置等更多內容,請參考如何安裝 OpenHarmony ohpm包
2.導入bignumber.js
import BigNumber from "bignumber.js";
3.調用接口
let x = new BigNumber(123.4567);let y = BigNumber('123456.7e-3');let z = new BigNumber(x);expect(x).assertEqual(y);expect(y).assertEqual(z);expect(x).assertEqual(z);
該庫導出單個構造函數(shù)BigNumber,該函數(shù)接受Number、String或BigNumber類型的值。
let x = new BigNumber('1111222233334444555566');x.toString(); // "1.111222233334444555566e+21"x.toFixed();//"1111222233334444555566"
要獲取BigNumber的字符串值,請使用toString()或toFixed()。
//使用超過15個有效數(shù)字的數(shù)字文字會導致精度損失。new BigNumber(1.0000000000000001) // '1'new BigNumber(88259496234518.57) // '88259496234518.56'new BigNumber(99999999999999999999) // '100000000000000000000'//使用數(shù)值范圍之外的數(shù)字文字會導致精度損失。new BigNumber(2e+308) // 'Infinity'new BigNumber(1e-324) // '0'//Number值的算術運算的意外結果導致精度損失。new BigNumber(0.7 +0.1)//'0.7999999999999999'
如果不太了解數(shù)字值的有限精度,建議從字符串值而不是數(shù)字值創(chuàng)建 BigNumbers,以避免潛在的精度損失。
new BigNumber(Number.MAX_VALUE.toString(2), 2)
從數(shù)字創(chuàng)建大數(shù)時,請注意,大數(shù)是從數(shù)字的十進制值創(chuàng)建的,而不是從其基礎二進制值創(chuàng)建的。如果需要后者,則傳遞Number的值并指定基數(shù)2.toString()或toString(2)。
a = new BigNumber(1011, 2) // "11"b = new BigNumber('zz.9', 36) // "1295.25"c=a.plus(b)
可以從 2 到 36 的基數(shù)中的值創(chuàng)建大數(shù)字。請參閱ALPHABET以擴展此范圍。
0.3 - 0.1 // 0.19999999999999998x = new BigNumber(0.3)x.minus(0.1) // "0.2"x//"0.3"
如果未為十進制值指定基數(shù)10,則性能更好。僅當要將輸入值的小數(shù)位數(shù)限制為當前INK http://mik設置時,才指定基數(shù)10。BigNumber是不可變的,因為它不會被其方法更改。
x.dividedBy(y).plus(z).times(9)x.times('1.23456780123456789e+9').plus(9876.5432321).dividedBy('4444562598.111772').integerValue()//"0.3"
返回BigNumber的方法可以鏈接。
x = new BigNumber(255.5)x.toExponential(5) // "2.55500e+2"x.toFixed(5) // "255.50000"x.toPrecision(5) // "255.50"x.toNumber()//255.5
BigNumber與JavaScript的Number類型一樣,有toExponential,toFixed和toPrecision方法。
x.toString(16) // "ff.8"
可以為toString指定基數(shù)。
如果沒有指定基數(shù)10,即使用toString()而不是toString(10),則性能會更好。如果要將字符串的小數(shù)位數(shù)限制為當前的DECIMAL_PLACES設置,請僅指定基數(shù)10。
y = new BigNumber('1234567.898765')
y.toFormat(2)//"1,234,567.90"
有一種toFormat方法可能對國際化有用。
y = new BigNumber(355)
pi = y.dividedBy(113) // "3.1415929204"
pi.toFraction() // [ "7853982301", "2500000000" ]
pi.toFraction(1000)//["355","113"]
有一個toFraction方法,它有一個可選的最大分母參數(shù)。
x = new BigNumber(NaN) // "NaN"
y = new BigNumber(Infinity) // "Infinity"
x.isNaN()&&!y.isNaN()&&!x.isFinite()&&!y.isFinite()
以及isNaN和isFinite方法,因為和是有效值。NaN、Infinity、BigNumber。
x = new BigNumber(-123.456);
x.c // [ 123, 45600000000000 ] coefficient (i.e. significand)
x.e // 2 exponent
x.s//-1sign
BigNumber的值以系數(shù)、指數(shù)和符號的十進制浮點格式存儲。
//為原始BigNumber構造函數(shù)設置DECIMAL_LACES
BigNumber.set({ DECIMAL_PLACES: 10 })
// 創(chuàng)建另一個BigNumber構造函數(shù),可選地傳入配置對象
BN = BigNumber.clone({ DECIMAL_PLACES: 5 })
x = new BigNumber(1)
y = new BN(1)
x.div(3) // '0.3333333333'
y.div(3)//'0.33333'
為了高級使用,可以創(chuàng)建多個BigNumber構造函數(shù),每個構造函數(shù)都有自己的獨立配置。
源碼地址&ohpm倉地址
https://gitee.com/openharmony-tpc/docs/blob/master/OpenHarmony_har_usage.md
https://ohpm.openharmony.cn/#/cn/detail/bignumber.js
https://gitee.com/openharmony-tpc/openharmony_tpc_samples/tree/master/bignumberjsDemo
https://ohpm.openharmony.cn/#/cn/detail/bignumber.js
原文標題:【開源三方庫】bignumber.js:一個大數(shù)數(shù)學庫
文章出處:【微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉載請注明出處。
-
鴻蒙
+關注
關注
57文章
2339瀏覽量
42805 -
OpenHarmony
+關注
關注
25文章
3713瀏覽量
16254
原文標題:【開源三方庫】bignumber.js:一個大數(shù)數(shù)學庫
文章出處:【微信號:gh_e4f28cfa3159,微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論