浮點數轉換成整數方法有很多,本例為大家介紹常用的三個方法,如果讀者想到其他好用方法,也可以交流一下
Summary
暫時我就想到3個方法而已。如果讀者想到其他好用方法,也可以交流一下
parseInt 位運算符 Math.floor Math.ceil
Description
一、parseInt
1. 實例
1 parseInt(
"13nash"
);
//13
2 parseInt(
""
)
// NaN
3 parseInt(
"0xA"
)
//10(十六進制)
4 parseInt(
" 13"
)
//13
5 parseInt(
"070"
)
//ES3為56(八進制) ES5為70
6 parseInt(070)
//ES3和ES5都為56
7 parseInt(22.5)
//22
2. 轉換規則:
(1). 根據實例(1)得出parseInt會解析一直到非數字時停止 (2). 根據實例(2)得出parseInt解析空字符串時為NaN,而不是0 (3). 根據實例(3)得出parseInt可以將16進制數轉換成10進制 (4). 根據實例(4)得出parseInt忽略字符串的空格
3. 缺點:
(1). 根據實例(5)我們可以知道parseInt在轉換八進制數組時是不兼容的。ES3會把070看成八進制數值,但是ES5會將070看成十進制。 (2). 根據實例(6)(7)我們可以知道parseInt在執行的時候會先把參數轉變成字符串后再執行變成整數
4. 解釋:為什么(5)(6)執行都是執行將070轉換成整數,但是結果不一樣呢?這個也是解決怎么得到缺點中的第二點。
因為在看官方文檔中我看到了If string is not a string, then it is converted to one。這段話。就是說參數如果不是字符串的話,它會先將它轉換成字符串再轉換成整數。比如實例(6)中parseInt(070),其實是先將070轉換成字符串,你可以試下070+""或者String(070)都可以知道070會被轉換成"56",因為070是一個八進制。然后就變成了parseInt("56"),最后得出來的整數就是56了。不管你在ES3或者ES5都是為56
二、位操作符
1. 實例
1 console.log(0 |
"123.45"
)
//123
2 console.log(0 | 123.45)
//123
3 console.log(0 ^ 123.45)
//123
4 console.log(~~123.45)
//123
三、Math.floor與Math.ceil
1. 實例
1 console.log(Math.floor(2.3)
//2
2 console.log(Math.floor(-2.3)
//-3
3 console.log(Math.ceil(2.3)
//3
4 console.log(Math.ceil(-2.3)
//-2
3. 解決:
//自行定義一個函數
function
getInt(val){
return
val>0 ? Math.floor(val):Math.ceil(val);
}