js中的||與&&用法

Drl龍發表於2018-07-04

js中的||與&&用法,對其用法研究了一下:

&&

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。

相關文章