JavaScript 布爾操作符解析 && || !
更新時間:2012年08月10日 17:14:15 作者:
在一門編程語言中,布爾操作符的重要性堪比相等操作符。如果沒有測試兩個值關(guān)系的能力,那么諸如if...else和循環(huán)之類的語句就不會有用武之地了。布爾操作符一共有3個: 非、與、或
1、邏輯非
邏輯非用!表示,可以應(yīng)用與ECMAScript的任何類型的值,邏輯非操作返回的是一個布爾值(true/false)。該操作符首先會將它的操作數(shù)轉(zhuǎn)換為一個布爾值,然后再對其求反。
下面說明下Boolean()轉(zhuǎn)型函數(shù)的一組規(guī)則。
Boolean()轉(zhuǎn)型函數(shù)的簡便表示方法。-----------!!
2、邏輯與
邏輯與操作符由兩個和號(&&)表示,有兩個操作數(shù)。
邏輯與操作可以應(yīng)用于任何類型的操作數(shù),而不僅僅是布爾值。在有一個操作數(shù)不是布爾值的情況下,邏輯與操作就不一定返回布爾值;此時,它遵循一下規(guī)則:
1. 如果第一個操作數(shù)是對象,則返回第二個操作數(shù);
2. 如果第二個操作數(shù)是對象,則只有在第一個操作數(shù)的求值結(jié)果為true的情況下才會返回該對象;
3. 如果兩個操作符都是對象,則返回第二個操作數(shù); 遵循第一規(guī)則。
4. 如果有一個操作是null,則返回null;
5. 如果有一個操作符是NaN,則返回NaN;
6. 如果有一個操作符是undefined,則返回undefined。
邏輯與操作屬于短路操作,即如果第一操作數(shù)能夠決定結(jié)果,那么就不會再對第二個操作數(shù)求值。(可以理解為內(nèi)部的兩個return操作)。因此當(dāng)4、5、6規(guī)則沖突時,遵循短路操作原則。
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
因此,我們來總結(jié)一下。&&操作主要遵循幾大原則:
1.短路操作原則;
2.求值過程中會被轉(zhuǎn)型生成副本,但是返回值是原來值;
// 偽代碼
function &&(param1,param2){
bparam1 = Boolean(param1);
if (!bparam1) return param1;
bparam2 = Boolean(param2);
return param2;
}
// 參數(shù)是一個對象時返回引用的指針值,函數(shù)同
3、邏輯或
邏輯或符號由兩個豎線符號(||)表示。
邏輯或符號同樣是短路操作符。其實現(xiàn)過程可以參照邏輯與的偽代碼。這里就不再列出一些規(guī)則了。
邏輯或常常用來做參數(shù)的缺省處理,比如 evt = evt || window.event;
邏輯非用!表示,可以應(yīng)用與ECMAScript的任何類型的值,邏輯非操作返回的是一個布爾值(true/false)。該操作符首先會將它的操作數(shù)轉(zhuǎn)換為一個布爾值,然后再對其求反。
下面說明下Boolean()轉(zhuǎn)型函數(shù)的一組規(guī)則。
| 數(shù)據(jù)類型 | 轉(zhuǎn)換為true的值 | 轉(zhuǎn)換為false的值 |
| Boolean | true | false |
| String | 任何非空字符串 | ""(空字符串) |
| Number | 任何非零數(shù)字值(包括無窮大) | 0和NaN |
| Object | 任何對象 | null |
| Undefined | 無 | undefined |
Boolean()轉(zhuǎn)型函數(shù)的簡便表示方法。-----------!!
2、邏輯與
邏輯與操作符由兩個和號(&&)表示,有兩個操作數(shù)。
邏輯與操作可以應(yīng)用于任何類型的操作數(shù),而不僅僅是布爾值。在有一個操作數(shù)不是布爾值的情況下,邏輯與操作就不一定返回布爾值;此時,它遵循一下規(guī)則:
1. 如果第一個操作數(shù)是對象,則返回第二個操作數(shù);
2. 如果第二個操作數(shù)是對象,則只有在第一個操作數(shù)的求值結(jié)果為true的情況下才會返回該對象;
3. 如果兩個操作符都是對象,則返回第二個操作數(shù); 遵循第一規(guī)則。
4. 如果有一個操作是null,則返回null;
5. 如果有一個操作符是NaN,則返回NaN;
6. 如果有一個操作符是undefined,則返回undefined。
邏輯與操作屬于短路操作,即如果第一操作數(shù)能夠決定結(jié)果,那么就不會再對第二個操作數(shù)求值。(可以理解為內(nèi)部的兩個return操作)。因此當(dāng)4、5、6規(guī)則沖突時,遵循短路操作原則。
復(fù)制代碼 代碼如下:
var nul = null;
var na = NaN;
var test;
test = na&&nul;
document.write(test); //NaN
復(fù)制代碼 代碼如下:
var nul = null;
var na = NaN;
var test;
test = nul&&na;
document.write(test); //null
因此,我們來總結(jié)一下。&&操作主要遵循幾大原則:
1.短路操作原則;
2.求值過程中會被轉(zhuǎn)型生成副本,但是返回值是原來值;
復(fù)制代碼 代碼如下:
// 偽代碼
function &&(param1,param2){
bparam1 = Boolean(param1);
if (!bparam1) return param1;
bparam2 = Boolean(param2);
return param2;
}
// 參數(shù)是一個對象時返回引用的指針值,函數(shù)同
3、邏輯或
邏輯或符號由兩個豎線符號(||)表示。
邏輯或符號同樣是短路操作符。其實現(xiàn)過程可以參照邏輯與的偽代碼。這里就不再列出一些規(guī)則了。
邏輯或常常用來做參數(shù)的缺省處理,比如 evt = evt || window.event;
相關(guān)文章
JS使用ActiveXObject實現(xiàn)用戶提交表單時屏蔽敏感詞功能
這篇文章主要介紹了JS采用ActiveXObject實現(xiàn)用戶在提交表單時屏蔽敏感詞的功能的相關(guān)資料,需要的朋友可以參考下2017-06-06
JavaScript動態(tài)改變HTML頁面元素例如添加或刪除
HTML頁面元素可以通過js動態(tài)改變,比如可以向HTML中添加元素或刪除某個元素,下面為示例代碼,感興趣的朋友不要錯過2014-08-08
解決前端接收 type:"application/octet-stream" 格
前端接收 type: “application/octet-stream“ 格式的數(shù)據(jù)并下載,還有后端既返回octet-stream還返回JSON數(shù)據(jù)時的處理方法,今天給大家分享前端接收 type:"application/octet-stream" 格式的數(shù)據(jù)并下載(解決后端返回不唯一問題)的解決方案,感興趣的朋友一起看看吧2023-12-12
JavaScript將頁面表格導(dǎo)出為Excel的具體實現(xiàn)
如何將頁面表格導(dǎo)出為Excel,這在日常工作中很常見,下面為大家詳細(xì)的介紹下使用JavaScript是如何實現(xiàn)的2013-12-12
利用Angularjs和Bootstrap前端開發(fā)案例實戰(zhàn)
這篇文章主要為大家介紹了利用Angularjs和Bootstrap前端開發(fā)案例實戰(zhàn),感興趣的小伙伴們可以參考一下2016-08-08

