溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JS位運(yùn)算符怎么用

發(fā)布時(shí)間:2022-02-08 09:34:12 來(lái)源:億速云 閱讀:171 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了JS位運(yùn)算符怎么用的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇JS位運(yùn)算符怎么用文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

按位與(AND)&

將數(shù)字轉(zhuǎn)換成二進(jìn)制,然后進(jìn)行與操作,再轉(zhuǎn)換回十進(jìn)制

// 1 的二進(jìn)制表示為 00000000 00000000 00000000 00000001// 3 的二進(jìn)制表示為 00000000 00000000 00000000 00000011// --------------------------------------------------// 1 的二進(jìn)制表示為 00000000 00000000 00000000 00000001console.log(1 & 3) // 1

按位或(OR)|

將數(shù)字轉(zhuǎn)換為二進(jìn)制,然后進(jìn)行或操作,再轉(zhuǎn)換回十進(jìn)制

// 1 的二進(jìn)制表示為 00000000 00000000 00000000 00000001// 3 的二進(jìn)制表示為 00000000 00000000 00000000 00000011// --------------------------------------------------// 3 的二進(jìn)制表示為 00000000 00000000 00000000 00000011console.log(1 | 3) // 3

按位異或(XOR)^

將數(shù)字轉(zhuǎn)換為二進(jìn)制,然后進(jìn)行異或操作,再轉(zhuǎn)換回十進(jìn)制

// 1 的二進(jìn)制表示為 00000000 00000000 00000000 00000001// 3 的二進(jìn)制表示為 00000000 00000000 00000000 00000011// --------------------------------------------------// 2 的二進(jìn)制表示為 00000000 00000000 00000000 00000010console.log(1 ^ 3) // 2

按位非(NOT)~

將數(shù)字轉(zhuǎn)換為二進(jìn)制,然后進(jìn)行非操作,再轉(zhuǎn)換回十進(jìn)制,也就求二進(jìn)制的反碼

// 1 反碼二進(jìn)制表示為 11111111 11111111 11111111 11111110// 由于第一位(符號(hào)位)是1,所以這個(gè)數(shù)是負(fù)數(shù)。JavaScript 內(nèi)部采用補(bǔ)碼形式表示負(fù)數(shù),即需要將這個(gè)數(shù)減去 1,再去一次反,然后加上負(fù)號(hào)才能得到這個(gè)負(fù)數(shù)對(duì)應(yīng)的十進(jìn)制數(shù)值// 1 的反碼減一表示為 11111111 11111111 11111111 11111101// 取反             00000000 00000000 00000000 00000010// 表示為 -2console.log(~1) // -2

左移(Left shift)<<

將數(shù)字轉(zhuǎn)換成二進(jìn)制,然后丟棄高位,低位補(bǔ)0

// 1 的二進(jìn)制表示為 00000000 00000000 00000000 00000001// 2 的二進(jìn)制表示為 00000000 00000000 00000000 00000010console.log(1 << 1) // 2

有符號(hào)右移 >>

將數(shù)字轉(zhuǎn)成二進(jìn)制,然后丟棄低位,拷貝最左側(cè)的位以填充左側(cè)

// 1 的二進(jìn)制表示為 00000000 00000000 00000000 00000001// 0 的二進(jìn)制表示為 00000000 00000000 00000000 00000000console.log(1 >> 1) // 0

無(wú)符號(hào)右移 >>>

將數(shù)字轉(zhuǎn)成二進(jìn)制,然后丟棄低位,左側(cè)補(bǔ)0,因此總是非負(fù)數(shù)。

對(duì)于非負(fù)數(shù),有符號(hào)右移和無(wú)符號(hào)右移結(jié)果總是相等。

位運(yùn)算符在 JS 中的妙用

判斷奇偶

// 偶數(shù) & 1 = 0// 奇數(shù) & 1 = 1console.log(2 & 1) // 0console.log(3 & 1) // 1

取整

console.log(~~6.83) // 6console.log(6.83 >> 0) // 6console.log(6.83 << 0) // 6console.log(6.83 | 0) // 6// 不可對(duì)負(fù)數(shù)取整console.log(6.83 >>> 0) // 6

交換值

var a = 6var b = 8a ^= bb ^= aa ^= bconsole.log(a) // 8console.log(b) // 6

RGB 值和16 進(jìn)制顏色值轉(zhuǎn)換

function hexToRGB(hex: string): string{  const hexx = hex.replace('#', '0x')  const r = hexx >> 16  const g = hexx >> 8 & 0xff  const b = hexx & 0xff  return `rgb(${r}, ${g}, $)`}function RGBToHex(rgb: string): string{  const rgbArr = rgb.split(/[^\d]+/)  const color = rgbArr[1] | rgbArr[2] << 8 | rgbArr[3]  return `#${color.toString(16)}`}

關(guān)于“JS位運(yùn)算符怎么用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“JS位運(yùn)算符怎么用”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI