js中parseInt()詭異行為的探究與改正
探討背景:
不知道小伙伴們有沒有發(fā)現(xiàn),如果是parseInt(0.006)或者parseInt(0.0006)等返回的值都應該 0,但是parseInt(0.0000006)返回的值卻詭異的 6,這到底為什么呢?
parseInt函數(shù)的作用
首先先說一下,parseInt()的作用是什么?他是js原生的方法,是用來把數(shù)字字符串轉化為Number類型的數(shù)字的,還有他只是轉化整數(shù)部分。
parse 是轉化,Int 是整型,整數(shù),目的是把里面轉換成整數(shù)
var num = parseInt(demo ,radix); //demo 是你要轉換的那個數(shù)
傳一個參數(shù)的用法
var demo =”123”; var num = parseInt(demo); console.log(typeof(num) + “:” + num);//number:123 var demo = true; var num = parseInt(demo); console.log(typeof(num) + “:” + num);//number: NaN var demo = false; var num = parseInt(demo); console.log(typeof(num) + “:” + num);//number: NaN var demo = 123.9; var num = parseInt(demo); console.log(typeof(num) + “:” + num);//number: 123,直接砍掉小數(shù)非四舍五入 var demo = “10”; var num = parseInt(demo ,16); console.log(typeof(num) + “:” + num); //number: 16
傳兩個參數(shù)的用法
var num = parseInt(demo ,radix); //radix 是基底的意思
解釋:radix 寫成 16,系統(tǒng)會認為是以 16 進制為基底, 10(一零)是 16 進制的一零,是以 16 進制為基底,把他轉成為 10 進制的數(shù)字(就是 16),上面是以目標進制為基底,轉換成十進制(radix 范圍是 2-36)
例:
//1、 parseInt(10,2)//結果是 2 因為把10看成是二進制把它轉換成10進制得2 //2 var demo = “123abc”; var num = parseInt(demo); console.log(typeof(num) + “:” + num);//結果:number: 123 //因為parseInt 從數(shù)字類開始看,看到非數(shù)字類為止,返回原來的數(shù)
探究原因
發(fā)現(xiàn)我們理想的是把這個小數(shù)都變成0,但是parseInt(0.0000006)卻返回6,真是離譜呀。
console.log(parseInt(0.006)) //0 console.log(parseInt(0.0006)) //0 console.log(parseInt(0.00006)) //0 console.log(parseInt(0.000006)) //0 console.log(parseInt(0.0000006)) //6
返回我就開始探索他的原因,是哪里出現(xiàn)了問題。
parseInt(0.0000006) //0.000006 String(0.0000006); //6e-7 parseInt(6e-7); //6 parseInt(0.0000006) //6
總結原因
這下我發(fā)現(xiàn)原因了,原來是因為在10的-6次方之后,形式就換成了復數(shù)的形式(6e-7)。然后用parseInt()把6e-7的6,進行了返回,所以最后返回的值是6。
改正
如果要把小數(shù)安全的返回回來,就要用別的方法啦!
Math.floor(0.00006); //0 Math.floor(0.000006); //0 Math.floor(0.0000006); //0
這樣就可以得到你想要的值了。
總結
到此這篇關于js中parseInt()詭異行為的文章就介紹到這了,更多相關js中parseInt()內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Bootstrapvalidator校驗、校驗清除重置的實現(xiàn)代碼(推薦)
這篇文章給大家介紹了bootstrapvalidator校驗、校驗清除重置的實現(xiàn)代碼,在代碼中需要我們引入css與js文件,大家可以參考下文的代碼2016-09-09

