JavaScript 學習筆記之操作符_基礎知識
一、一元運算子
1、自增自減操作符:分為前置型與後置型;
前置型: a;--a;
後置型:a ;a--;
例:
其中a=i ,相當於a=i;i=i 1;
而b= j,相當於j=j 1;b=j;
2、一元加減運算子:a= i;a=-i;
對整數而言,一元減相當於取負數。
二、位元運算子
1、位元非~ (NOT)
非,即以二進位形式將所有數字取反。
常見用法:位元運算 NOT 實質上是對數字求負,然後減 1
2、位元或| (OR)
或,即以二進位形式將所有的數字與目標數字按位進行或操作。
常見用法:通常用於二進制數字的無條件賦值。例如:一個數字|1,相當於與取得與目前數字最接近的奇數。
3、位元與& (AND)
與,即以二進位形式將所有的數字與目標數字按位進行與操作。
常見用法:通常用於二進位的取位操作,例如:一個數字&1,如果結果為0則為偶數,如果為1則為奇數。
4、位元異或^ (XOR)
異或,即以二進位形式將所有數字與目標數字對比,只有兩個數字不相同即只有一個數字存放的是1的時候返回1,如兩個數字相同返回0.
常見用法:xor運算的逆運算是它本身,也就是說兩次異或同一個數最後結果不變。可以用於簡單的加密,或互動數值操作。
5、左移
左移,即以二進位形式把所有的數字向左移動對應的位數,高位移出(捨棄),低位的空位補零。左移不會影響符號位。
數學意義:在數字沒有溢出的前提下,對於正數和負數,左移一位都相當於乘以2的1次方,左移n位就相當於乘以2的n次方。
6、右移
6.1有符號的右移>>:即以二進位形式把所有的數值向右移動但是保留符號位。
數學意義:在數字沒有溢出的前提下,對於正數和負數,右移一位都相當於除以2的1次方,右移n位就相當於除以2的n次方。
6.2無符號的右移>>>:即以二進位形式把所有的數值,包括符號位都向右移動。
對於正數來說>>和>>>的結果是一樣的;
對負數來說,由於負數以其絕對值的補碼形式表示,因此會導致無符號右移結果非常大。
三、布林運算子
1、邏輯非 !
邏輯非用!表示,可以套用與ECMAScript的任何類型的值,邏輯非操作傳回的是一個布林值(true/false)。該運算符首先會將它的操作數轉換為一個布林值,然後再對其求反.
! !相當於Boolean()函數。
Boolean()轉換函數的一組規則。
資料型別 轉換為true的值 轉換為false的值
Boolean true false
String 任何非空白字串 ""(空白字串)
Number 任何非零數字值(包括無限大) 0和NaN
Object 任何對象 null
Undefined 無 undefined
2、邏輯與&&
邏輯與有兩個運算元。
邏輯與操作可以應用於任何類型的操作數,而不僅僅是布林值。在有一個操作數不是布林值的情況下,邏輯與操作就不一定會傳回布林值;此時,它遵循一下規則:
1. 如果第一個操作數是對象,則返回第二個操作數;
2. 如果第二個操作數是對象,則只有在第一個操作數的求值結果為true的情況下才會返回該對象;
3. 如果兩個運算符都是對象,則傳回第二個操作數; 遵循第一規則。
4. 如果有一個運算元是null,則回傳null;
5. 如果有一個操作數是NaN,則回傳NaN;
6. 如果有一個運算元是undefined,則回傳undefined。
邏輯與操作屬於短路操作,也就是如果第一操作數能夠決定結果,那麼就不會再對第二個操作數求值。 (可以理解為內部的兩個return操作)。因此當4、5、6規則衝突時,遵循短路操作原則。
var nul = null;
var na = NaN;
var test;
test = na&&nul;
document.write(test); //NaN
var nul = null;
var na = NaN;
var test;
test = nul&&na;
document.write(test); //null
3、邏輯或||
邏輯或有兩個操作數。
邏輯或與邏輯與相似,操作可以應用於任何類型的操作數,而不僅僅是布林值。在有一個操作數不是布林值的情況下,邏輯或操作就不一定會傳回布林值;此時,它遵循一下規則:
1. 如果第一個操作數是對象,則傳回第一個操作數;
2. 如果第一個操作數的結果是false,則傳回第二個操作數;
3. 如果兩個運算符都是對象,則傳回第一個操作數,遵循第一條規則。
4. 如果兩個運算元都是null,則回傳null;
5. 如果兩個運算元都是NaN,則回傳NaN;
6. 如果兩個運算元都是undefined,則回傳undefined。
邏輯或操作屬於短路操作,也就是如果第一個操作數結果為true,那麼就不會再對第二個操作數求值。
我們可以利用邏輯或的這個特性來避免為變數賦null或undefined的值
例如:var myObject=firstObject||secondObject
如果firstObject不是null,則firstObject被賦值給myObject,否則將secondObject的值賦給myObject.
以上內容就是本文的全部了,希望對大家能有所幫助

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript是一種廣泛應用於Web開發的程式語言,而WebSocket則是一種用於即時通訊的網路協定。結合二者的強大功能,我們可以打造一個高效率的即時影像處理系統。本文將介紹如何利用JavaScript和WebSocket來實作這個系統,並提供具體的程式碼範例。首先,我們需要明確指出即時影像處理系統的需求和目標。假設我們有一個攝影機設備,可以擷取即時的影像數
