JavaScript中的運算符有很多,主要分為算術運算符,等同全同運算符,比較運算符,字串運算符,邏輯運算符,賦值運算符等。這些運算子都有一些屬於自己的運算規則,以下就來為大家介紹一下JavaScript中的運算子。
一、JavaScript運算子的種類
1、算術運算子: 、 - 、* 、 / 、 % 、 -(一元取反) 、 --
2、等同全同運算子:== 、 ===、 !== 、 !===
3、比較運算子: 、 =
4、字串運算子: 、 = 、 = 、
5、邏輯運算子:&& 、 ||、 !、
賦值運算子:=、 =、 *=、 -=、 /=
二、JavaScript運算子的規則
1、算術運算子規則
1、算術運算子規則 「 」:可以進行「加法」與「連接」運算;如果2個運算子中的一個是字串,javascript就將另一個轉換成字串,然後將2個運算數連接起來。
「 」:如果一個運算數是對象,javascript就會將對象轉換成數字做加法運算或字串做連接運算;
「-」「*」「/」 如果做連接運算;
「-」「*」「/」 如果2個運算數中的一個是是非數字,則將它轉換成數字執行數學運算。
「/」 在javascript中,由於所有的數都是浮點數,除法的結果都是浮點數,5 / 2 = 2.5 ;除數為0的結果為正負無窮;0/0為NaN;
「%」模運算子:計算第一個運算數對第二個運算數的模,就是第一個運算數被第二個運算數除時,傳回餘數。如果運算數是非數字的,則轉換成數字。
「-」一元取反:將運算數取反,如果運算數不是數字,則轉換成數字。
「 」「--」增量運算子/減量運算符號:運算數必須是一個變數、樹組的一個元素或物件的屬性。如果運算數不是數字,則轉換成數字。
注意:如果「 」位於運算數之前,先對運算數進行增量,然後計算運算數增長後的值。
如果「--」位於運算數之後,先計算運算數未成長之前的值,再將運算數增量。
例如:i = 1; //賦值給i值1
j = i; //先將i增量為2,然後將2賦值為j,i的值是2,j的值也是2。
i = 1; //賦值給i值1
j = i ; //先將i賦值給j,然後將i值增量到2,i的值是2,j的值是1。
減量運算子「--」與「 」相同。
2、等同運算子與全同運算子
(I)「==」「!==」等同運算子與非等同運算子:
『 2個運算數,傳回一個不布林值。
比較數值、字串、布林值使用的都是量值。當且僅當兩個變數存放的值相等的時候,他們才相等。
比較物件、陣列、函數的時候,使用的是引用,只有2個變數引用的是同一個物件時,他們才是相等的。兩個不同的陣列是完全不同的,即使他們有完全相同的元素。對於存放物件、陣列、函數的引用的變數來說,只有當他們引用的是同一個物件、陣列、函數的時候,他們才相等。
注意!應遵循的原則:
當兩個運算數的類型不同時:將他們轉換成相同的類型,
1)一個數字與一個字符串,字串轉換成數字之後,進行比較。
2)true轉換為1、false轉換為0,進行比較。
3)一個物件、陣列、函數 與 一個數字或字串,物件、陣列、函數轉換為原始類型的值,然後進行比較。 (先使用valueOf,如果不行就使用toString)
4)其他類型的組合不星等。
想兩個運算數型別相同,或轉換成相同型別後:
1)2個字串:同一位置上的字元相等,2個字串就相同。
2)2個數字:2個數字相同,就相同。如果一個是NaN,或兩個都是NaN,則不相同。
3)2個都是true,或2個都是false,則想同。
4)2個引用的是同一個物件、函數、數組,則相等,如果引用的不是同一個物件、函數、數組,則不相同,即使這2個物件、函數、數組可以轉換成完全相等的原始值。
5)2個null,或2個都是未定義的,那麼他們相等。 「!=」非等同運算子:與等同運算子偵測的結果相反。
(II)「===」「!===」全同運算子與非全同運算子:
全同運算子遵循運算子的比較規則,但是它不會對運算數進行型別轉換,當兩個運算數的型別不同時,傳回false;只有當兩個運算數的型別相同的時候,才遵循等同運算子的比較規則進行比較。
「!==」非全同運算子與全同運算子比較的結果相反。如果兩個運算數的型別或值不同的時候,回傳true。
3、比較運算子
這些比較運算子用來比較不同類型的值,結果傳回一個布林值。
「」「=」
注意規則:比較的運算數可以是任意類型的,但是只能在數字和運算數上執行。不是數字和字串的運算數將被轉換成數字或字串。
1)如果兩個運算數都是數字,或者都可以轉換成數字,則按照數字的大小進行比較;
2)如果兩個運算數都是字串,或者都可以轉換成字串,則將按照字母順序進行比較;
3)如果字串遇到數字,則將字串轉換成數字進行比較。
4)如果運算數既不能轉換成數字,也不能轉換成字串,則傳回結果false。
4、字串運算子
並沒有專用的字串運算符,只是有些運算子在遇到字串運算數的時候,表現不同。
(I)「 」連接2個字串;
1)當2個運算數都是字串的時候,連接起來;
2)當其中有一個是數字的時候,將數字轉換成字串,連接起來;
(II)「>」這樣的比較運算子透過比較確認兩個字串的順序,比較採用字元的順序,較小的位於教大的前面,大寫字母位於小寫字母之前。
(III)「 」的作用方法取決於計算順序,
如:s = 1 2 "var" 則:傳回結果 3var; 因為先計算1 2,然後將結果 3轉換成字串與"var"連接;
如:s = "var" 1 2 則:傳回結果var12; 因為先計算var與1的連接,在將結果var1與轉換成字串的2連接起來。
5、邏輯運算子
用於執行布林運算,常常和比較運算子一起使用,來表示複雜的比較運算。
「&&」 邏輯與運算、「||」邏輯或運算子、「!」邏輯非運算子
(I)「&&」當兩個運算數都是布林值的時候,邏輯與對他們進行and操作,即:當且僅當兩個布林值都是true的時候,返回結果true,否則返回false。
注意:實際表現
「&&」將偵測第一個表達式運算數布林值,如果第一個運算數運算式傳回false,則傳回左邊第一個運算數表達式的值:false;否則將繼續偵測第二個即右邊的運算數表達式,然後傳回第二個運算數表達式的值;
例如:if (a = b) stop( ); 與(a = b) && stop(); 等價
不贊成使用這個方法,因為運算子右邊的程式碼不能保證會被執行,
例如:if (( a
將「&&」看作是一個布林代數的運算符,會比較簡單與安全。
(II)「||」當兩個運算數都是布林值的時候,邏輯或對他們進行or操作,即:當兩個布林值有一個是true的時候,回傳結果true ,否則回傳false。
注意:實際表現
「||」將偵測第一個表達式運算數布林值,如果第一個運算數運算式傳回true,則傳回左邊第一個運算數字表達式的值:true;否則將繼續偵測第二個即右邊的運算數表達式,然後傳回第二個運算數表達式的值;
同樣不贊成使用這個方法,因為運算符右邊的程式碼不能保證會被執行,
一般反對在||的右邊使用具有其他作用的表達式(賦值、函數呼叫、增減量);
將「| |」看作是一個布林代數的運算符,會更簡單與安全。
(III)「!」邏輯非是一個一元運算符,放在運算數之前,它的目的是對運算數取反。
6、賦值運算子
(I)「=」是賦值運算子;他總是期望左邊的運算數是一個變數、陣列的一個元素或物件的一個屬性;
期望右邊是一個任意類型的任意的值;
從右到左的結合性,如果一個表達式中有多個賦值運算符,則從最右邊開始計算。
注: 各代入式には値があり、これは演算子の右側の値です。(II) 演算
で代入演算を使用できます。 “= 左側の値が右側の値に加算され、左側の値に代入されます。 「-=」「/=」「*=」は同じメソッドです。
7. 他の演算子
「?:」条件演算子は唯一の三項演算子です。 > 式のブール結果? 式 1 (任意の型の任意の値): 式 2 (任意の型の任意の値)
最初のオペランドのブール結果に基づいて、それが true の場合、 2 番目のオペランド式が実行され、2 番目のオペランド式の値が返されます。最初のオペランドのブール結果が false の場合、3 番目のオペランド式が実行され、2 番目のオペランド式の値が返されます。表現。
3. JavaScript 演算子に関する注意事項
1. 演算子に渡されるデータ型と返されるデータ型に注意してください オペランド式が評価するものは異なります。データ型に準拠した結果に変換されます。 例: 文字列の乗算は実行できません。「a」*「b」は不正ですが、可能な場合は、JavaScript が式を正しい型に変換するため、式「3」*「5」となります。 JavaScript は文字列を数値に変換し、その結果は文字列「15」ではなく数値 15 になります。
2. オペランドに応じて異なるパフォーマンス:
String string = string (connected); "a" "b" = "ab" "5" "6" = "11"
文字列番号 = (数値に変換された文字列) 文字列 (連結); "a" 5 = "a5" 5 は文字列 "1" 0 = "10" に変換されます
数値数値 = 数値(追加) 5 5 = 10。
3. 演算子の結合性に注意してください。一部の演算子は左から右に結合します。また、一部の演算子は右から左に結合します。
例: w = a b c は w = (a b) c と等価です。
は w = ---b は w = - ( - ( -b ) ) と等価です。 a = b = c は、w= ( a = ( b = c ))
単項演算子、代入演算子、および三項演算子の結合性は右から左です。
JavaScriptここではオペレーターの紹介をさせていただきますので、皆様の日常生活のお役に立てれば幸いです。