點擊藍字 ╳ 關注我們
特點
使用場景
使用示例
1.安裝bignumber.js
ohpminstallbignumber.js
OpenHarmony ohpm環境配置等更多內容,請參考如何安裝 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);
該庫導出單個構造函數BigNumber,該函數接受Number、String或BigNumber類型的值。
let x = new BigNumber('1111222233334444555566');x.toString(); // "1.111222233334444555566e+21"x.toFixed();//"1111222233334444555566"
要獲取BigNumber的字符串值,請使用toString()或toFixed()。
//使用超過15個有效數字的數字文字會導致精度損失。new BigNumber(1.0000000000000001) // '1'new BigNumber(88259496234518.57) // '88259496234518.56'new BigNumber(99999999999999999999) // '100000000000000000000'//使用數值范圍之外的數字文字會導致精度損失。new BigNumber(2e+308) // 'Infinity'new BigNumber(1e-324) // '0'//Number值的算術運算的意外結果導致精度損失。new BigNumber(0.7 +0.1)//'0.7999999999999999'
如果不太了解數字值的有限精度,建議從字符串值而不是數字值創建 BigNumbers,以避免潛在的精度損失。
new BigNumber(Number.MAX_VALUE.toString(2), 2)
從數字創建大數時,請注意,大數是從數字的十進制值創建的,而不是從其基礎二進制值創建的。如果需要后者,則傳遞Number的值并指定基數2.toString()或toString(2)。
a = new BigNumber(1011, 2) // "11"b = new BigNumber('zz.9', 36) // "1295.25"c=a.plus(b)
可以從 2 到 36 的基數中的值創建大數字。請參閱ALPHABET以擴展此范圍。
0.3 - 0.1 // 0.19999999999999998x = new BigNumber(0.3)x.minus(0.1) // "0.2"x//"0.3"
如果未為十進制值指定基數10,則性能更好。僅當要將輸入值的小數位數限制為當前INK http://mik設置時,才指定基數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指定基數。
如果沒有指定基數10,即使用toString()而不是toString(10),則性能會更好。如果要將字符串的小數位數限制為當前的DECIMAL_PLACES設置,請僅指定基數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方法,它有一個可選的最大分母參數。
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的值以系數、指數和符號的十進制浮點格式存儲。
//為原始BigNumber構造函數設置DECIMAL_LACES
BigNumber.set({ DECIMAL_PLACES: 10 })
// 創建另一個BigNumber構造函數,可選地傳入配置對象
BN = BigNumber.clone({ DECIMAL_PLACES: 5 })
x = new BigNumber(1)
y = new BN(1)
x.div(3) // '0.3333333333'
y.div(3)//'0.33333'
為了高級使用,可以創建多個BigNumber構造函數,每個構造函數都有自己的獨立配置。
源碼地址&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:一個大數數學庫
文章出處:【微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉載請注明出處。
-
鴻蒙
+關注
關注
57文章
2387瀏覽量
42962 -
OpenHarmony
+關注
關注
25文章
3744瀏覽量
16470
原文標題:【開源三方庫】bignumber.js:一個大數數學庫
文章出處:【微信號:gh_e4f28cfa3159,微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論