Javascript的&&和||的另類用法
最近也沒什么心思寫文章了,感覺總有忙不完的事情,呵。 不過這些天又開始研究起 Titanium 來,發(fā)現(xiàn)其官方出品的MVC框架(Alloy)還是挺不錯的,剛開始苦于沒有好的代碼來學(xué)習(xí),文檔又少,所以一直沒去詳細(xì)研究,后來發(fā)現(xiàn)原來官方的 CodeStrong 就是一套非常不錯的學(xué)習(xí)代碼,只要看通了其整套代碼,相信對Alloy的使用也基本會了~
在看其源碼的同時(shí),發(fā)現(xiàn)很多地方使用了諸如以下的用法:
$.clouds && ($.index.add($.clouds));
開始不是很理解,畢竟平時(shí)這樣用的也少,上了下google后才知道原來這樣寫法非常方便好用(其實(shí)jquery的源碼里也大量使用此方法)。以下引用一段網(wǎng)上找到的解釋&&和||在javascript中的另類用法:
a() && b() :如果執(zhí)行a()后返回true,則執(zhí)行b()并返回b的值;如果執(zhí)行a()后返回false,則整個表達(dá)式返回a()的值,b()不執(zhí)行;
a() || b() :如果執(zhí)行a()后返回true,則整個表達(dá)式返回a()的值,b()不執(zhí)行;如果執(zhí)行a()后返回false,則執(zhí)行b()并返回b()的值;
&& 優(yōu)先級高于 ||
看完后就相當(dāng)清楚了,再看看具體代碼:
alert((1 && 3 || 0) && 4); //結(jié)果4 ① alert(1 && 3 || 0 && 4); //結(jié)果3 ② alert(0 && 3 || 1 && 4); //結(jié)果4 ③
分析:
語句①:1&&3 返回3 => 3 || 0 返回 3 => 3&&4 返回 4
語句②:先執(zhí)行1&&3 返回3,在執(zhí)行0&&4返回0,最后執(zhí)行結(jié)果比較 3||0 返回 3
語句③:先執(zhí)行0&&3 返回0,在執(zhí)行1&&4返回4,最后執(zhí)行結(jié)果比較 0||4 返回 4
注:非0的整數(shù)都為true,undefined、null和空字符串”” 為false。
感覺javascript確實(shí)挺強(qiáng)挺靈活的哦,呵呵~~
相關(guān)文章
URLSearchParams快速解析URL查詢參數(shù)實(shí)現(xiàn)
這篇文章主要為大家介紹了URLSearchParams快速解析URL查詢參數(shù)實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
JavaScript避免代碼的重復(fù)執(zhí)行經(jīng)驗(yàn)技巧分享
經(jīng)常會發(fā)現(xiàn)一個問題,那就是重復(fù)的代碼執(zhí)行,下面就是一些在查看它們的源代碼時(shí)發(fā)現(xiàn)一些問題,把這些分享給大家,希望能讓你們更加簡潔高效的寫出JavaScript代碼2014-04-04
JavaScript實(shí)現(xiàn)替換字符串中最后一個字符的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)替換字符串中最后一個字符的方法,涉及javascript字符串的轉(zhuǎn)換與運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2017-03-03
JavaScript利用事件循環(huán)實(shí)現(xiàn)數(shù)據(jù)預(yù)加載
當(dāng)我們請求好第一頁數(shù)據(jù)后,將請求下一頁放到異步任務(wù)隊(duì)列里(宏任務(wù)或者微任務(wù)),等當(dāng)前同步任務(wù)執(zhí)行完成后,立馬請求下一頁數(shù)據(jù),本文給大家介紹了JavaScript如何利用事件循環(huán)實(shí)現(xiàn)數(shù)據(jù)預(yù)加載,需要的朋友可以參考下2024-05-05
使用javascript創(chuàng)建快捷方式的簡單實(shí)例
這篇文章介紹了使用javascript創(chuàng)建快捷方式的簡單實(shí)例,有需要的朋友可以參考一下2013-08-08

