JavaScript實(shí)現(xiàn)大數(shù)的運(yùn)算
對(duì)于非常大或非常小的數(shù),可以用科學(xué)記數(shù)法表示浮點(diǎn)值。采用科學(xué)記數(shù)法,可以把一個(gè)數(shù)表示為數(shù)字加e/E,后面加乘以10的倍數(shù),如:
var num1 = 3.125e7; // 31250000 var num2 = 3e-17; // 0.00000000000000003
進(jìn)行特別大的數(shù)的加減運(yùn)算,可以使用字符串+科學(xué)記數(shù)法的方法來(lái)進(jìn)行,如:
// 這里只考慮大整數(shù)的情況,不考慮小數(shù) function strAdd(sNum1, sNum2){
/*增加一位數(shù)位以記錄最高位進(jìn)一的情況*/
var sNum1 = ['0', sNum1].join(''), sNum2 = ['0', sNum2].join('');
/*給短的數(shù)字字符串加補(bǔ)0*/
var len1 = sNum1.length, len2 = sNum2.length,
zeroArr = function(len){
var arr = new Array(len), i=len;
while(i--){arr[i] = 0;}
return arr;
};
if(len1 > len2){
var arrTemp = zeroArr(len1 - len2);
arrTemp.push(sNum2),
sNum2 = arrTemp.join('');
}
else if(len2 > len1){
var arrTemp = zeroArr(len2 - len1);
arrTemp.push(sNum1),
sNum1 = arrTemp.join('');
}
/*將字符串轉(zhuǎn)換為數(shù)組,以相應(yīng)數(shù)位來(lái)相加*/
var arr1 = sNum1.split(''), arr2 = sNum2.split('');
var arrAddRes = new Array(arr1.length), i=arr1.length;
var andone = 0, // 低位相加是否進(jìn)一 cur1, cur2, curAdd;
while(i--){
cur1 = +arr1[i], cur2 = +arr2[i];
curAdd = cur1+cur2+andone;
if(10 > curAdd)
arrAddRes[i] = curAdd,
andone = 0;
else
arrAddRes[i] = +curAdd.toString().slice(1,2),
andone = 1;
}
if(!andone){ // 最后是否進(jìn)一,否則截取前面的0 arrAddRes.splice(0,1);
}
/*數(shù)組截取前19位如果有,用科學(xué)記數(shù)法來(lái)表示這個(gè)結(jié)果*/
var keeplen = 19; // js的小數(shù)只保留小數(shù)點(diǎn)后的18位 var eAfter = arrAddRes.length - 1; // e后面的倍數(shù)部分 var eBefore, eBeforeStr = ''; // e前面的小數(shù)部分
if(keeplen < arrAddRes.length)
eBeforeStr = [arrAddRes[0], '.', arrAddRes.slice(1, keeplen).join('')].join('');
else
eBeforeStr = [arrAddRes[0], '.', arrAddRes.slice(1).join('')].join('');
eBefore = +eBeforeStr;
return [Number(arrAddRes.join('')), eBefore, eAfter];
}
strAdd('1234567890', '9876543210'); // -> [1111111100, 1.1111111, 9]
代碼如上了,是不是也很簡(jiǎn)單呢。
相關(guān)文章
jquery form表單獲取內(nèi)容以及綁定數(shù)據(jù)
這篇文章主要介紹了jquery form表單獲取內(nèi)容以及form表單綁定數(shù)據(jù),獲取表單的數(shù)據(jù)保存到數(shù)據(jù)庫(kù),或者將數(shù)據(jù)綁定到form表單,感興趣的小伙伴們可以參考一下2016-02-02
javascript用rem來(lái)做響應(yīng)式開發(fā)
這篇文章主要介紹了javascript用rem來(lái)做響應(yīng)式開發(fā),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-01-01
two.js之實(shí)現(xiàn)動(dòng)畫效果示例
本篇文章主要介紹了two.js之實(shí)現(xiàn)動(dòng)畫效果示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2017-11-11
Web componentd組件內(nèi)部事件回調(diào)及痛點(diǎn)剖析
這篇文章主要為大家介紹了Web componentd組件內(nèi)部事件回調(diào)示例及其痛點(diǎn)的剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2021-11-11
JavaScript offset實(shí)現(xiàn)鼠標(biāo)坐標(biāo)獲取和窗口內(nèi)模塊拖動(dòng)
在頁(yè)面開發(fā)時(shí)我們少不了各種鼠標(biāo)交互動(dòng)作,那么JavaScript中如何實(shí)現(xiàn)鼠標(biāo)坐標(biāo)獲取和窗口內(nèi)模塊拖動(dòng),本文就詳細(xì)的介紹一下,感興趣的可以了解一下2021-05-05
js中的值類型和引用類型小結(jié) 文字說明與實(shí)例
下面就舉例講一下這兩種類型在JavaScript中的體現(xiàn)、用法及注意事項(xiàng)。2010-12-12
JS基于onclick事件實(shí)現(xiàn)單個(gè)按鈕的編輯與保存功能示例
這篇文章主要介紹了JS基于onclick事件實(shí)現(xiàn)單個(gè)按鈕的編輯與保存功能,結(jié)合實(shí)例形式分析了JS實(shí)現(xiàn)onclick響應(yīng)事件的轉(zhuǎn)換相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02

