首頁  >  文章  >  web前端  >  JavaScript中的||與&&用法(詳解)

JavaScript中的||與&&用法(詳解)

青灯夜游
青灯夜游轉載
2018-10-08 14:49:502160瀏覽

&&和||在JQuery原始碼內特別使用廣泛,由網路找了些例子作為參考,對其用法研究了一下:

&&

function a(){
    alert("a");
    return true;
}
function b(){
    alert("b");
    return true;
}
var c=a()&&b();
alert(c);

a() && b() :如果執行a()後傳回true,則執行b()並傳回b的值;如果執行a()後傳回false,則整個表達式傳回a()的值,b()不執行;

||

function a(){
    alert("a");
    return true;
}
function b(){
    alert("b");
    return false;
}
var c=a()||b();
alert(c);

a() || b() :如果執行a()後面回傳true,則整個表達式傳回a()的值,b()不執行;如果執行a()後傳回false,則執行b()並傳回b()的值;

&& 優先權高於||

alert((1 && 3 || 0) && 4); //結果4 ①
alert(1 && 3 || 0 && 4); //結果3 ②
alert(0 && 3 || 1 && 4); //結果4 ③

  分析:
  語句①:1&&3 回傳3 => 3 || 0 回傳3 => 3&&4 回傳4
  語句②:先執行1&&3 回傳3,在執行0&&4回傳0,最後執行結果比較3||0 回傳3
  語句③:先執行0&&3 回傳0,在執行1&&4回傳4,最後執行結果比較0||4 回傳4

註:非0的整數都為true,undefined、null和空字串」" 為false。

在 javascript 中,對於 && 不僅僅可以用於 boolean 類型,也不僅僅傳回 Boolean 類型的結果。 
l 如果第一個運算元是 Boolean 類型,且值為 false ,那麼直接傳回 false。 
l 如果第一個運算元是 Boolean 類型,而且值為 true,另外一個運算元是 object 類型,那麼將會傳回這個物件。 
l 如果兩個運算元都是 object 類型,那麼,回傳第二個物件。 
l 如果任何一個運算元是 null,那麼,回傳 null。 
l 如果任何一個運算元是 NaN,那麼回傳 NaN。 
l 如果任何一個運算元是 undefinded,那麼回傳 undefined。

alert(false && alice); // false 
alert(true && alice); // alice 
alert(alice && smith); // smith 
alert(smith && alice); // alice 
alert(null && alice); // null 
alert(NaN && alice); // NaN 
alert(undefined && alice); // undefined 
alert(alice && undefined); // undefined

對|| 來說,同樣也不僅僅用於Boolean 類型,也不僅僅返回Boolean 類型的結果。 

事實上,null、undefined、NaN 都會被視為 false。而對像被當作 true。 

l 如果第一個運算元是 boolean 型,且值為 true, 那麼,直接傳回 true。 
l 如果第一個運算元是 Boolean 類型,且值為 false ,第二個運算元為 object,則傳回 object 物件。 
l 如果兩個運算元都是 object 類型,那麼傳回第一個物件。 
l 如果兩個運算元都是 null,那麼,回傳 null。 
l 如果兩個運算元都是 NaN,那麼回傳 NaN。 
l 如果兩個運算元都是 undefined,那麼,回傳 undefined。 

alert(false || alice);     // alice
alert(true || alice);     // true
alert(alice || smith);     // alice
alert(smith || alice);     // smith
alert(null || alice);     // alice
alert(alice || null);     // alice
alert(null || null);     // null
alert(NaN || alice);      // alice
alert(alice || NaN);      // alice
alert(NaN || NaN);       // NaN
alert(undefined || alice);   // alice
alert(alice || undefined);   // alice
alert(undefined || undefined); // undefined

不用搞得這麼複雜 推薦大家看這部分的說明

#

a && b : 將a, b轉換為Boolean類型, 再執行邏輯與, true返回b, false返回a 
a || b : 將a, b轉換為Boolean類型, 再執行邏輯或, true回傳a, false回傳b 

轉換規則: 
物件為true 
非零數字為true 
非空白字串為true 
其他為false 

#以上就是本章的全部內容,更多相關教學請造訪JavaScript影片教學

以上是JavaScript中的||與&&用法(詳解)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除