JavaScript 布爾操作符解析 && || !
邏輯非用!表示,可以應(yīng)用與ECMAScript的任何類型的值,邏輯非操作返回的是一個(gè)布爾值(true/false)。該操作符首先會(huì)將它的操作數(shù)轉(zhuǎn)換為一個(gè)布爾值,然后再對(duì)其求反。
下面說(shuō)明下Boolean()轉(zhuǎn)型函數(shù)的一組規(guī)則。
數(shù)據(jù)類型 | 轉(zhuǎn)換為true的值 | 轉(zhuǎn)換為false的值 |
Boolean | true | false |
String | 任何非空字符串 | ""(空字符串) |
Number | 任何非零數(shù)字值(包括無(wú)窮大) | 0和NaN |
Object | 任何對(duì)象 | null |
Undefined | 無(wú) | undefined |
Boolean()轉(zhuǎn)型函數(shù)的簡(jiǎn)便表示方法。-----------!!
2、邏輯與
邏輯與操作符由兩個(gè)和號(hào)(&&)表示,有兩個(gè)操作數(shù)。
邏輯與操作可以應(yīng)用于任何類型的操作數(shù),而不僅僅是布爾值。在有一個(gè)操作數(shù)不是布爾值的情況下,邏輯與操作就不一定返回布爾值;此時(shí),它遵循一下規(guī)則:
1. 如果第一個(gè)操作數(shù)是對(duì)象,則返回第二個(gè)操作數(shù);
2. 如果第二個(gè)操作數(shù)是對(duì)象,則只有在第一個(gè)操作數(shù)的求值結(jié)果為true的情況下才會(huì)返回該對(duì)象;
3. 如果兩個(gè)操作符都是對(duì)象,則返回第二個(gè)操作數(shù); 遵循第一規(guī)則。
4. 如果有一個(gè)操作是null,則返回null;
5. 如果有一個(gè)操作符是NaN,則返回NaN;
6. 如果有一個(gè)操作符是undefined,則返回undefined。
邏輯與操作屬于短路操作,即如果第一操作數(shù)能夠決定結(jié)果,那么就不會(huì)再對(duì)第二個(gè)操作數(shù)求值。(可以理解為內(nèi)部的兩個(gè)return操作)。因此當(dāng)4、5、6規(guī)則沖突時(shí),遵循短路操作原則。
var nul = null;
var na = NaN;
var test;
test = na&&nul;
document.write(test); //NaN
var nul = null;
var na = NaN;
var test;
test = nul&&na;
document.write(test); //null
因此,我們來(lái)總結(jié)一下。&&操作主要遵循幾大原則:
1.短路操作原則;
2.求值過(guò)程中會(huì)被轉(zhuǎn)型生成副本,但是返回值是原來(lái)值;
// 偽代碼
function &&(param1,param2){
bparam1 = Boolean(param1);
if (!bparam1) return param1;
bparam2 = Boolean(param2);
return param2;
}
// 參數(shù)是一個(gè)對(duì)象時(shí)返回引用的指針值,函數(shù)同
3、邏輯或
邏輯或符號(hào)由兩個(gè)豎線符號(hào)(||)表示。
邏輯或符號(hào)同樣是短路操作符。其實(shí)現(xiàn)過(guò)程可以參照邏輯與的偽代碼。這里就不再列出一些規(guī)則了。
邏輯或常常用來(lái)做參數(shù)的缺省處理,比如 evt = evt || window.event;
相關(guān)文章
JS使用ActiveXObject實(shí)現(xiàn)用戶提交表單時(shí)屏蔽敏感詞功能
這篇文章主要介紹了JS采用ActiveXObject實(shí)現(xiàn)用戶在提交表單時(shí)屏蔽敏感詞的功能的相關(guān)資料,需要的朋友可以參考下2017-06-06JS獲取字符對(duì)應(yīng)的ASCII碼實(shí)例
下面小編就為大家?guī)?lái)一篇JS獲取字符對(duì)應(yīng)的ASCII碼實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就想給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09JavaScript動(dòng)態(tài)改變HTML頁(yè)面元素例如添加或刪除
HTML頁(yè)面元素可以通過(guò)js動(dòng)態(tài)改變,比如可以向HTML中添加元素或刪除某個(gè)元素,下面為示例代碼,感興趣的朋友不要錯(cuò)過(guò)2014-08-08JavaScript實(shí)現(xiàn)簡(jiǎn)單圖片輪播效果
這篇文章主要介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單圖片輪播效果,點(diǎn)擊下標(biāo)切換到該圖片上,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08js實(shí)現(xiàn)登錄框鼠標(biāo)拖拽效果
本文主要介紹了js實(shí)現(xiàn)登錄框鼠標(biāo)拖拽效果的實(shí)例,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03解決前端接收 type:"application/octet-stream" 格
前端接收 type: “application/octet-stream“ 格式的數(shù)據(jù)并下載,還有后端既返回octet-stream還返回JSON數(shù)據(jù)時(shí)的處理方法,今天給大家分享前端接收 type:"application/octet-stream" 格式的數(shù)據(jù)并下載(解決后端返回不唯一問(wèn)題)的解決方案,感興趣的朋友一起看看吧2023-12-12JavaScript將頁(yè)面表格導(dǎo)出為Excel的具體實(shí)現(xiàn)
如何將頁(yè)面表格導(dǎo)出為Excel,這在日常工作中很常見(jiàn),下面為大家詳細(xì)的介紹下使用JavaScript是如何實(shí)現(xiàn)的2013-12-12利用Angularjs和Bootstrap前端開(kāi)發(fā)案例實(shí)戰(zhàn)
這篇文章主要為大家介紹了利用Angularjs和Bootstrap前端開(kāi)發(fā)案例實(shí)戰(zhàn),感興趣的小伙伴們可以參考一下2016-08-08JavaScript實(shí)現(xiàn)日期格式化的操作詳解
在我們做業(yè)務(wù)開(kāi)發(fā)的漫長(zhǎng)歲月里,會(huì)多次跟時(shí)間打交道,相信大多數(shù)小伙伴對(duì)日期格式化也并不陌生,本文簡(jiǎn)單記錄了JavaScript實(shí)現(xiàn)日期格式化的過(guò)程,以及一些拓展,希望對(duì)大家有所幫助2023-05-05