DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript 布爾操作符解析 && || !
JavaScript 布爾操作符解析 && || !
編輯:關於JavaScript     
1、邏輯非

邏輯非用!表示,可以應用與ECMAScript的任何類型的值,邏輯非操作返回的是一個布爾值(true/false)。該操作符首先會將它的操作數轉換為一個布爾值,然後再對其求反。

下面說明下Boolean()轉型函數的一組規則。
數據類型 轉換為true的值 轉換為false的值 Boolean true false String   任何非空字符串 ""(空字符串) Number  任何非零數字值(包括無窮大) 0和NaN Object 任何對象 null Undefined  無 undefined
Boolean()轉型函數的簡便表示方法。-----------!!

2、邏輯與

邏輯與操作符由兩個和號(&&)表示,有兩個操作數。

邏輯與操作可以應用於任何類型的操作數,而不僅僅是布爾值。在有一個操作數不是布爾值的情況下,邏輯與操作就不一定返回布爾值;此時,它遵循一下規則:

1. 如果第一個操作數是對象,則返回第二個操作數;
2. 如果第二個操作數是對象,則只有在第一個操作數的求值結果為true的情況下才會返回該對象;
3. 如果兩個操作符都是對象,則返回第二個操作數; 遵循第一規則。
4. 如果有一個操作是null,則返回null;
5. 如果有一個操作符是NaN,則返回NaN;
6. 如果有一個操作符是undefined,則返回undefined。

邏輯與操作屬於短路操作,即如果第一操作數能夠決定結果,那麼就不會再對第二個操作數求值。(可以理解為內部的兩個return操作)。因此當4、5、6規則沖突時,遵循短路操作原則。

復制代碼 代碼如下:
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


因此,我們來總結一下。&&操作主要遵循幾大原則:

1.短路操作原則;
2.求值過程中會被轉型生成副本,但是返回值是原來值;

復制代碼 代碼如下:
// 偽代碼
function &&(param1,param2){
bparam1 = Boolean(param1);
if (!bparam1) return param1;
bparam2 = Boolean(param2);
return param2;
}
// 參數是一個對象時返回引用的指針值,函數同


3、邏輯或

邏輯或符號由兩個豎線符號(||)表示。
邏輯或符號同樣是短路操作符。其實現過程可以參照邏輯與的偽代碼。這裡就不再列出一些規則了。
邏輯或常常用來做參數的缺省處理,比如 evt = evt || window.event;
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved