解釋&&和||在javascript中的另類用法
又開始研究起 Titanium 來,發(fā)現(xiàn)其官方出品的MVC框架(Alloy)還是挺不錯的,剛開始苦于沒有好的代碼來學習,文檔又少,所以一直沒去詳細研究,后來發(fā)現(xiàn)原來官方的 CodeStrong 就是一套非常不錯的學習代碼,只要看通了其整套代碼,相信對Alloy的使用也基本會了~
在看其源碼的同時,發(fā)現(xiàn)很多地方使用了諸如以下的用法:
$.clouds && ($.index.add($.clouds));
開始不是很理解,畢竟平時這樣用的也少,上了下google后才知道原來這樣寫法非常方便好用(其實jquery的源碼里也大量使用此方法)。以下引用一段網(wǎng)上找到的解釋&&和||在javascript中的另類用法:
a() && b() :如果執(zhí)行a()后返回true,則執(zhí)行b()并返回b的值;如果執(zhí)行a()后返回false,則整個表達式返回a()的值,b()不執(zhí)行;
a() || b() :如果執(zhí)行a()后返回true,則整個表達式返回a()的值,b()不執(zhí)行;如果執(zhí)行a()后返回false,則執(zhí)行b()并返回b()的值;
&& 優(yōu)先級高于 ||
看完后就相當清楚了,再看看具體代碼:
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
語句②:先執(zhí)行1&&3 返回3,在執(zhí)行0&&4返回0,最后執(zhí)行結果比較 3||0 返回 3
語句③:先執(zhí)行0&&3 返回0,在執(zhí)行1&&4返回4,最后執(zhí)行結果比較 0||4 返回 4
注:非0的整數(shù)都為true,undefined、null和空字符串”” 為false。
感覺javascript確實挺強挺靈活的!!
相關文章
JavaScript中getUTCMinutes()方法的使用詳解
這篇文章主要介紹了JavaScript中getUTCMinutes()方法的使用詳解,是JS入門學習中的基礎知識,需要的朋友可以參考下2015-06-06window.requestAnimationFrame是什么意思,怎么用
window.requestAnimationFrame 告訴瀏覽器您要執(zhí)行的動畫并且請求瀏覽器的在下一個動畫幀重繪窗口,方法在瀏覽器重繪之前作為一個回調函數(shù)被調用,就是告訴瀏覽器在刷新屏幕的時候,調用這個方法2013-01-01