解釋&&和||在javascript中的另類用法
又開(kāi)始研究起 Titanium 來(lái),發(fā)現(xiàn)其官方出品的MVC框架(Alloy)還是挺不錯(cuò)的,剛開(kāi)始苦于沒(méi)有好的代碼來(lái)學(xué)習(xí),文檔又少,所以一直沒(méi)去詳細(xì)研究,后來(lái)發(fā)現(xiàn)原來(lái)官方的 CodeStrong 就是一套非常不錯(cuò)的學(xué)習(xí)代碼,只要看通了其整套代碼,相信對(duì)Alloy的使用也基本會(huì)了~
在看其源碼的同時(shí),發(fā)現(xiàn)很多地方使用了諸如以下的用法:
$.clouds && ($.index.add($.clouds));
開(kāi)始不是很理解,畢竟平時(shí)這樣用的也少,上了下google后才知道原來(lái)這樣寫(xiě)法非常方便好用(其實(shí)jquery的源碼里也大量使用此方法)。以下引用一段網(wǎng)上找到的解釋&&和||在javascript中的另類用法:
a() && b() :如果執(zhí)行a()后返回true,則執(zhí)行b()并返回b的值;如果執(zhí)行a()后返回false,則整個(gè)表達(dá)式返回a()的值,b()不執(zhí)行;
a() || b() :如果執(zhí)行a()后返回true,則整個(gè)表達(dá)式返回a()的值,b()不執(zhí)行;如果執(zhí)行a()后返回false,則執(zhí)行b()并返回b()的值;
&& 優(yōu)先級(jí)高于 ||
看完后就相當(dāng)清楚了,再看看具體代碼:
alert((1 && 3 || 0) && 4); //結(jié)果4 ①
alert(1 && 3 || 0 && 4); //結(jié)果3 ②
alert(0 && 3 || 1 && 4); //結(jié)果4 ③
分析:
語(yǔ)句①:1&&3 返回3 => 3 || 0 返回 3 => 3&&4 返回 4
語(yǔ)句②:先執(zhí)行1&&3 返回3,在執(zhí)行0&&4返回0,最后執(zhí)行結(jié)果比較 3||0 返回 3
語(yǔ)句③:先執(zhí)行0&&3 返回0,在執(zhí)行1&&4返回4,最后執(zhí)行結(jié)果比較 0||4 返回 4
注:非0的整數(shù)都為true,undefined、null和空字符串”” 為false。
感覺(jué)javascript確實(shí)挺強(qiáng)挺靈活的!!
相關(guān)文章
JavaScript對(duì)象學(xué)習(xí)經(jīng)驗(yàn)整理
主要包括對(duì)象的創(chuàng)建、對(duì)象屬性的設(shè)置和查詢、對(duì)象方法等等,整理如下,感興趣的朋友可以參考下2013-10-10Javascript技術(shù)棧中的四種依賴注入小結(jié)
本文總結(jié)了Javascript中常見(jiàn)的依賴注入方式,并以inversify.js為例,介紹了方言社區(qū)對(duì)于Javascript中DI框架的嘗試和初步成果2016-02-02javascript 學(xué)習(xí)筆記(四) 倒計(jì)時(shí)程序代碼
javascript 學(xué)習(xí)筆記(四) 倒計(jì)時(shí)程序代碼,需要的朋友可以參考下。2011-04-04JavaScript中g(shù)etUTCMinutes()方法的使用詳解
這篇文章主要介紹了JavaScript中g(shù)etUTCMinutes()方法的使用詳解,是JS入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-06-06window.requestAnimationFrame是什么意思,怎么用
window.requestAnimationFrame 告訴瀏覽器您要執(zhí)行的動(dòng)畫(huà)并且請(qǐng)求瀏覽器的在下一個(gè)動(dòng)畫(huà)幀重繪窗口,方法在瀏覽器重繪之前作為一個(gè)回調(diào)函數(shù)被調(diào)用,就是告訴瀏覽器在刷新屏幕的時(shí)候,調(diào)用這個(gè)方法2013-01-01優(yōu)化JavaScript腳本的性能的幾個(gè)注意事項(xiàng)
優(yōu)化JavaScript腳本的性能的幾個(gè)注意事項(xiàng)...2006-12-12詳解JS-- 浮點(diǎn)數(shù)運(yùn)算處理
本篇文章主要介紹了JS--浮點(diǎn)數(shù)運(yùn)算處理,現(xiàn)在分享給大家,也給大家做個(gè)參考。感興趣的小伙伴們可以參考一下。2016-11-11JavaScript中匿名、命名函數(shù)的性能測(cè)試
這篇文章主要介紹了JavaScript中匿名、命名函數(shù)的性能測(cè)試,簡(jiǎn)單來(lái)講匿名即沒(méi)有名字的函數(shù),它和命名函數(shù)相比性能如何呢,本文即是對(duì)它們性能的測(cè)試,需要的朋友可以參考下2014-09-09