詳解JavaScript中|單豎杠運算符的使用方法
js運算符單豎杠“|”的作用
在js整數(shù)操作的時候,相當于去除小數(shù)點,parseInt。在正數(shù)的時候相當于Math.floor(),負數(shù)的時候相當于Math.ceil() 注:
1. Math.ceil()用作向上取整。
2. Math.floor()用作向下取整。
3. Math.round() 我們數(shù)學中常用到的四舍五入取整。
console.log(0.6|0)//0 console.log(1.1|0)//1 console.log(3.65555|0)//3 console.log(5.99999|0)//5 console.log(-7.777|0)//-7
注:除了Math的三個方法處理數(shù)字,我們還經常用parseInt()、parseFloat()、toFixed()與toPrecision() 等等。 簡單解釋:
toFixed方法用法如下:
100.456001.toFixed(2); //100.47 100.456001.toFixed(3); //100.456 Number.prototype.toFixed.call(100.456001,2); //100.47
缺點:用之后就會變成字符串。
toPrecision用法如下:
99.456001.toPrecision(5); //99.456 100.456001.toPrecision(5); //100.46 Number.prototype.toPrecision.call(10.456001,5); //10.456
單豎杠的運算規(guī)則
看了上面的例子,大體知道單豎杠可以進行取整運算,就是只保留正數(shù)部分,小數(shù)部分通過拿掉,但是“|0”,又是如何進行運算的呢,為什么能“|0”能達到取整的目的呢?單豎杠不是0有會是多少呢?
帶著這些問題,我們看下面例子:
console.log(3|4); //7 console.log(4|4);//4 console.log(8|3);//11 console.log(5.3|4.1);//5 console.log(9|3455);//3455
好吧,我在這里公布答案吧。其實單豎杠“|”就是轉換為2進制之后相加得到的結果。例如我們拿簡單的舉例:
轉換為二進制之后011|100 相加得到111=7
轉換為二進制之后100 |100 相加得到100=4
轉換為二進制之后1000 |011 相加得到1011=11
相關文章
深入理解JavaScript系列(41):設計模式之模板方法詳解
這篇文章主要介紹了深入理解JavaScript系列(41):設計模式之模板方法詳解,模板方法(TemplateMethod)定義了一個操作中的算法的骨架,而將一些步驟延遲到子類中,模板方法使得子類可以不改變一個算法的結構即可重定義該算法的某些特定步驟,需要的朋友可以參考下2015-03-03
javascript中判斷一個值是否在數(shù)組中并沒有直接使用
在JS中要判斷一個值是否在數(shù)組中并沒有函數(shù)直接使用,如PHP中就有in_array()這個函數(shù),可以寫一個類似in_array()函數(shù)功能的方法2012-12-12
初學JS的的小例子 javascript replace高亮替換
初學JS的的小例子 javascript replace高亮替換...2007-12-12

