JavaScript邏輯運(yùn)算符相關(guān)總結(jié)
前言
關(guān)于 JavaScript 中的邏輯運(yùn)算符,我們經(jīng)常使用卻可能不知道它的一些機(jī)制和用法。
機(jī)制
首先我們需要知道幾種邏輯運(yùn)算符的優(yōu)先級是不同的(關(guān)于完整的運(yùn)算符優(yōu)先級,看運(yùn)算符優(yōu)先級),邏輯非>邏輯與>邏輯或>條件運(yùn)算符(三目運(yùn)算符)。運(yùn)算順序條件運(yùn)算符是從右向左,而邏輯與和邏輯或都是從左向右。
//表達(dá)式的優(yōu)先級導(dǎo)致結(jié)果不同false && true || true // 結(jié)果為 truefalse && (true || true) // 結(jié)果為 false
邏輯運(yùn)算表達(dá)式返回的是字表達(dá)式的值,而不是一個(gè) Boolean,只不過很多時(shí)候我們使用邏輯表達(dá)式的地方幫我們強(qiáng)制轉(zhuǎn)換了,比如 if 語句等。
邏輯運(yùn)算符通常用于布爾型(邏輯)值。這種情況下,它們返回一個(gè)布爾值。然而, && 和 || 運(yùn)算符會返回一個(gè)指定操作數(shù)的值,因此,這些運(yùn)算符也用于非布爾值。這時(shí),它們也就會返回一個(gè)非布爾型值。
邏輯與 expression1 && expression2 的機(jī)制是,如果 expression1 能夠轉(zhuǎn)換為 true 那么返回 expression2 ,否則返回 expression1。
邏輯或 expression1 || expression2 的機(jī)制是,如果 expression1 能夠轉(zhuǎn)化為 true 那么返回 expression1,否則返回 expression2。
邏輯非 !expression ,若 expression 能夠轉(zhuǎn)化為 true 則返回 false,否則返回 true。
expression 可能是任何一種類型, 不一定是布爾值。
會被轉(zhuǎn)化為 false 的表達(dá)式有:
null NaN 0 空字符串('' or ’’ or“` “ “`) undefined需要特別注意的是 undefined,有些表達(dá)式返回的是 undefined ,比如沒有設(shè)置 return 的函數(shù)執(zhí)行的返回值就是 undefined。
盡管 && 和 || 運(yùn)算符能夠使用非布爾值的操作數(shù), 但它們依然可以被看作是布爾操作符,因?yàn)樗鼈兊姆祷刂悼偸悄軌虮晦D(zhuǎn)換為布爾值。如果要顯式地將它們的返回值(或者表達(dá)式)轉(zhuǎn)換為布爾值,請使用雙重非運(yùn)算符(即!!)或者 Boolean 構(gòu)造函數(shù)。
雙重非運(yùn)算符 !! 可以將任意值強(qiáng)制轉(zhuǎn)換為布爾值,在需要條件判斷的地方經(jīng)常使用。
短路計(jì)算
邏輯運(yùn)算的機(jī)制還存在短路計(jì)算:
(some falsy expression1) && (expression2) 短路計(jì)算的結(jié)果為假。 (some truthy expression1) || (expression2) 短路計(jì)算的結(jié)果為真。短路意味著上述表達(dá)式中的 expression2 部分不會被執(zhí)行,因此 expression2 的任何副作用都不會生效(舉個(gè)例子,如果 expression 是一次函數(shù)調(diào)用,這次調(diào)用就不會發(fā)生)。造成這種現(xiàn)象的原因是,整個(gè)表達(dá)式的值在第一個(gè)操作數(shù)被計(jì)算后已經(jīng)確定了。
用法
利用 javascript 中邏輯運(yùn)算符支持任意類型和短路計(jì)算的特性我們可以將邏輯運(yùn)算符運(yùn)用到一些特殊的地方。
邏輯與
邏輯與可以用來獲得第一個(gè)假值,比如 expr1 && expr2 && expr3,當(dāng)其中存在假值的時(shí)候會被返回。也可以類推至前面的表達(dá)式都為真的時(shí)候執(zhí)行最后一個(gè)表達(dá)式來簡化判斷邏輯的代碼,比如 x > 0 && a(),這可以代替 if 語句。
邏輯或
邏輯或可以用來設(shè)置默認(rèn)值,比如你的函數(shù)需要用戶輸入一個(gè)參數(shù),如果用戶沒有輸入則給定一個(gè)默認(rèn)值。this.a = param || {}。
以上就是JavaScript邏輯運(yùn)算符相關(guān)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于JavaScript邏輯運(yùn)算符的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. python實(shí)現(xiàn)讀取類別頻數(shù)數(shù)據(jù)畫水平條形圖案例2. python中PyQuery庫用法分享3. python操作數(shù)據(jù)庫獲取結(jié)果之fetchone和fetchall的區(qū)別說明4. JSP動(dòng)態(tài)實(shí)現(xiàn)web網(wǎng)頁登陸和注冊功能5. Ajax實(shí)現(xiàn)頁面無刷新留言效果6. php使用正則驗(yàn)證密碼字段的復(fù)雜強(qiáng)度原理詳細(xì)講解 原創(chuàng)7. CSS3實(shí)現(xiàn)動(dòng)態(tài)翻牌效果 仿百度貼吧3D翻牌一次動(dòng)畫特效8. PHP獲取時(shí)間戳等相關(guān)函數(shù)匯總9. php5.6不能擴(kuò)展redis.so的解決方法10. AJAX實(shí)現(xiàn)數(shù)據(jù)的增刪改查操作詳解【java后臺】
