最近發(fā)現(xiàn)JS當(dāng)中toFixed方法存在一些問(wèn)題。toFixed這個(gè)函數(shù)一直在用,以前都是把 Number 四舍五入為指定小數(shù)位數(shù)的數(shù)字,沒(méi)有考慮其他。今天需要考慮擴(kuò)展一下功能,于是搜索了一下,竟然發(fā)現(xiàn)了一個(gè)大坑。
請(qǐng)看下面的例子:
- var num = 3.15;
- var n = num.toFixed(1);
- console.log(n);
而打印結(jié)果是3.1!
說(shuō)好的四舍五入呢?不急,再看下面的例子:
- var num = 3.25;
- var n = num.toFixed(1);
- console.log(n);
納尼?3.3!這下又四舍五入了。why?網(wǎng)上有人據(jù)此整理出“四舍六入,五看奇偶”的原則,就是說(shuō)大于五的就進(jìn)一位,五呢偶進(jìn)奇不進(jìn)。那么是不是這樣呢?請(qǐng)看下面的例子:
- var num1 = 3.55;
- var num2 = 3.65;
- var num3 = 3.05;
- var n1 = num1.toFixed(1);
- var n2 = num2.toFixed(1);
- var n3 = num3.toFixed(1);
- console.log(n1,n2,n3);
效果預(yù)覽:
圖片1.png (4.69 KB, 下載次數(shù): 1)
下載附件
2016-6-13 15:02 上傳
file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wps50B3.tmp.jpg
按照“四舍六入,五看奇偶”的原則,n1==3.5是對(duì)的,n2==3.7才是, n3==3.1(這里不討論0算不算偶數(shù),根據(jù)我小學(xué)知識(shí)算它偶數(shù))才對(duì)嘛。然并卵,機(jī)器是不會(huì)騙人的。
根據(jù)測(cè)試,2、3、4、7、8、9這幾個(gè)都會(huì)四舍五入。
還有誰(shuí)不懵逼的?。?/span>
根據(jù)多方查證,完美的處理方式是自己改寫(xiě)這個(gè)函數(shù)。
至于JavaScript內(nèi)部是為什么,沒(méi)去摳。有興趣的同學(xué)可以去研究下,希望不吝賜教。
當(dāng)然,對(duì)于大多數(shù)情況,這個(gè)問(wèn)題也不是什么問(wèn)題。
另外,附帶提一下push()。網(wǎng)上有的同學(xué)把join錯(cuò)寫(xiě)成push時(shí)出了問(wèn)題,形如下面:
- //目標(biāo),希望得到1
- var arr = ["1"];
- console.log(arr.join(","));
- //錯(cuò)寫(xiě),結(jié)果得到2
- var arr = ["1"];
- console.log(arr.push(","));
效果預(yù)覽:
圖片2.png (3.16 KB, 下載次數(shù): 1)
下載附件
2016-6-13 15:03 上傳
file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wps50C4.tmp.jpgwhy?其實(shí)我們仔細(xì)點(diǎn)就可以發(fā)現(xiàn),join那里打印出來(lái)的是字符串"1",push那里打印出來(lái)的是數(shù)字2。
join()把數(shù)組中的所有元素轉(zhuǎn)換為一個(gè)字符串,返回結(jié)果---轉(zhuǎn)換后的字符串。
push()是往數(shù)組中添加新元素,返回結(jié)果---新數(shù)組的長(zhǎng)度。