詳解JavaScript邏輯And運(yùn)算符
在JavaScript中,邏輯 AND 運(yùn)算符用雙和號(hào)(&&)表示
var bTrue = true; var bFalse = false; var bResult = bTrue && bFalse;
下面的真值表描述了邏輯AND運(yùn)算符的行為:
需要說(shuō)明的是:邏輯AND運(yùn)算的運(yùn)算數(shù)可以是任何類型的,不止是Boolean值,如果某個(gè)運(yùn)算數(shù)不是原始的Boolean型值,邏輯AND運(yùn)算并不一定返回Boolean值
邏輯AND運(yùn)算符的運(yùn)算行為如下:
- 如果一個(gè)運(yùn)算數(shù)是對(duì)象,另一個(gè)是 Boolean 值,返回該對(duì)象。
- 如果兩個(gè)運(yùn)算數(shù)都是對(duì)象,返回第二個(gè)對(duì)象。
- 如果某個(gè)運(yùn)算數(shù)是 null,返回 null。
- 如果某個(gè)運(yùn)算數(shù)是 NaN,返回 NaN。
- 如果某個(gè)運(yùn)算數(shù)是 undefined,發(fā)生錯(cuò)誤。
- 如果兩個(gè)運(yùn)算數(shù)都是boolean類型,則返回boolean值
與Java中的邏輯AND運(yùn)算相似,JavaScript 中的邏輯AND運(yùn)算也是簡(jiǎn)便運(yùn)算,即如果第一個(gè)運(yùn)算數(shù)決定了結(jié)果,就不再計(jì)算第二個(gè)運(yùn)算數(shù)。對(duì)于邏輯AND運(yùn)算來(lái)說(shuō),如果第一個(gè)運(yùn)算數(shù)是false,那么無(wú)論第二個(gè)運(yùn)算數(shù)的值是什么,結(jié)果都不可能等于true。
考慮下面的例子:
var bTrue = true; var bResult = (bTrue && bUnknown); //發(fā)生錯(cuò)誤 alert(bResult); //這一行不會(huì)執(zhí)行
代碼運(yùn)行結(jié)果:
這段代碼在進(jìn)行邏輯 AND 運(yùn)算時(shí)將引發(fā)錯(cuò)誤,因?yàn)樽兞?bUnknown 是未定義的。變量 bTrue 的值為 true,因?yàn)檫壿?AND 運(yùn)算將繼續(xù)計(jì)算變量 bUnknown。這樣做就會(huì)引發(fā)錯(cuò)誤,因?yàn)?bUnknown 的值是 undefined,不能用于邏輯 AND 運(yùn)算。
如果修改這個(gè)例子,把第一個(gè)數(shù)設(shè)為 false,那么就不會(huì)發(fā)生錯(cuò)誤:
var bTrue = false; var bResult = (bTrue && bUnknown); //不會(huì)發(fā)生錯(cuò)誤 alert("bTrue && bUnknown的結(jié)果是:"+(bResult));//輸出 "false"
在這段代碼中,腳本將輸出邏輯AND運(yùn)算返回的值,即字符串"false"。即使變量 bUnknown 的值為 undefined,它也不會(huì)被計(jì)算,因?yàn)榈谝粋€(gè)運(yùn)算數(shù)的值是 false。
運(yùn)行結(jié)果:
驗(yàn)證JavaScript邏輯And運(yùn)算符的運(yùn)算行為
測(cè)試代碼:
<script type="text/javascript"> document.write("驗(yàn)證JavaScript邏輯And運(yùn)算符的運(yùn)算行為:"); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); var bTrue = true; var bFalse = false; var bResult = bTrue && bFalse; /*1.如果兩個(gè)運(yùn)算數(shù)都是boolean類型,則返回boolean值*/ document.write("1.如果兩個(gè)運(yùn)算數(shù)都是boolean類型,則返回boolean值"); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); document.write("bTrue = true,bFalse = false,bTrue && bFalse的結(jié)果是:"+(bResult));//結(jié)果為false document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); var obj = new Object(); /*2.如果一個(gè)運(yùn)算數(shù)是對(duì)象,另一個(gè)是 Boolean 值,返回該對(duì)象*/ document.write("2.如果一個(gè)運(yùn)算數(shù)是對(duì)象,另一個(gè)是 Boolean 值,返回該對(duì)象"); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); document.write("obj是一個(gè)對(duì)象,true&&obj的結(jié)果是:"+(true&&obj)); document.write("<br/>"); document.write("obj==true&&obj的結(jié)果是:"+(obj==(true&&obj))); document.write("<br/>"); document.write("false&&obj的結(jié)果是:"+(false&&obj)); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); /*3.如果兩個(gè)運(yùn)算數(shù)都是對(duì)象,返回第二個(gè)對(duì)象。*/ var obj1 = new Object(); var obj2 = new Object(); document.write("3.如果兩個(gè)運(yùn)算數(shù)都是對(duì)象,返回第二個(gè)對(duì)象。"); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); document.write("obj1是一個(gè)對(duì)象,obj2是一個(gè)對(duì)象,obj1==(obj1&&obj2)的結(jié)果是:"+(obj1==(obj1&&obj2)));//結(jié)果為false document.write("<br/>"); document.write("obj1是一個(gè)對(duì)象,obj2是一個(gè)對(duì)象,obj2==(obj1&&obj2)的結(jié)果是:"+(obj2==(obj1&&obj2)));//結(jié)果為true document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); /*4.如果某個(gè)運(yùn)算數(shù)是 null,返回null。*/ var a=null; var b=true; document.write("4.如果某個(gè)運(yùn)算數(shù)是 null,返回null。"); document.write("<br/>"); document.write("a=null,b=true,a&&b的結(jié)果是:"+(a&&b)); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); /*5.如果某個(gè)運(yùn)算數(shù)是NaN,返回NaN*/ var c = NaN; var d = "str"; document.write("5.如果某個(gè)運(yùn)算數(shù)是NaN,返回NaN"); document.write("<br/>"); document.write("c=NaN,d=str,c&&d的結(jié)果是:"+(c&&d)); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); /* 6.JavaScript中的邏輯 AND 運(yùn)算是簡(jiǎn)便運(yùn)算,即如果第一個(gè)運(yùn)算數(shù)決定了結(jié)果,就不再計(jì)算第二個(gè)運(yùn)算數(shù)。 對(duì)于邏輯 AND 運(yùn)算來(lái)說(shuō),如果第一個(gè)運(yùn)算數(shù)是 false,那么無(wú)論第二個(gè)運(yùn)算數(shù)的值是什么,結(jié)果都不可能等于 true。 */ var bFalse = false; var bResult = (bFalse && bUnknown); document.write("6.JavaScript中的邏輯 AND 運(yùn)算是簡(jiǎn)便運(yùn)算,即如果第一個(gè)運(yùn)算數(shù)決定了結(jié)果,就不再計(jì)算第二個(gè)運(yùn)算數(shù)"); document.write("<br/>"); document.write("對(duì)于邏輯 AND 運(yùn)算來(lái)說(shuō),如果第一個(gè)運(yùn)算數(shù)是 false,那么無(wú)論第二個(gè)運(yùn)算數(shù)的值是什么,結(jié)果都不可能等于 true。"); document.write("<br/>"); document.write("bFalse=false,bUnknown是一個(gè)未定義的變量,bFalse && bUnknown的結(jié)果是:"+(bResult)); //輸出 "false" var bTrue = true; var bResult = (bTrue && bUnknown); //發(fā)生錯(cuò)誤 alert(bResult); //這一行不會(huì)執(zhí)行 </script>
以上就是關(guān)于JavaScript邏輯And運(yùn)算符的全部介紹,希望能夠幫助到大家更好的學(xué)習(xí)js的邏輯運(yùn)算符。
- JS邏輯運(yùn)算符短路操作實(shí)例分析
- javaScript 邏輯運(yùn)算符使用技巧整理
- 老生常談javascript中邏輯運(yùn)算符&&和||的返回值問(wèn)題
- 深入了解JavaScript的邏輯運(yùn)算符(與、或)
- 巧用Javascript的邏輯運(yùn)算符
- javascript運(yùn)算符——邏輯運(yùn)算符全面解析
- JavaScript知識(shí)點(diǎn)總結(jié)(四)之邏輯OR運(yùn)算符詳解
- 詳解JavaScript邏輯Not運(yùn)算符
- js比較和邏輯運(yùn)算符的介紹
- js的邏輯運(yùn)算符 ||
- JavaScript邏輯運(yùn)算符相關(guān)總結(jié)
相關(guān)文章
JavaScript實(shí)現(xiàn)獲取圖片文件真實(shí)格式的示例代碼
每種格式的圖片,都有自己特有的優(yōu)缺點(diǎn)以及數(shù)據(jù)結(jié)構(gòu),本篇博文的目的就是基于不同格式的圖像二進(jìn)制數(shù)據(jù),獲取到圖片的真實(shí)格式,感興趣的可以了解一下2023-02-02javascript中apply和call方法的作用及區(qū)別說(shuō)明
本篇文章主要是對(duì)javascript中apply和call方法的作用及區(qū)別進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02JavaScript立即執(zhí)行函數(shù)的三種不同寫法
這篇文章主要介紹了JavaScript立即執(zhí)行函數(shù)的三種不同寫法,需要的朋友可以參考下2014-09-09javascript實(shí)現(xiàn)圖片輪播簡(jiǎn)單效果
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)圖片輪播簡(jiǎn)單效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07多瀏覽器兼容的動(dòng)態(tài)加載 JavaScript 與 CSS
Omar AL Zabir這位MVP總是喜歡搞些稀奇古怪同時(shí)又很實(shí)用的小東西,并且還十分值得參考。最近他就做了一個(gè)叫做ensure的小工具用于動(dòng)態(tài)加載JavaScript、CSS與HTML,而且IE、Firefox、Opera、Safari都支持了,那么我們就來(lái)看看ensure是如何做到動(dòng)態(tài)加載JavaScript與CSS的。2008-09-09解析ES6中的解構(gòu)賦值(數(shù)組,對(duì)象,嵌套,默認(rèn)值)
解構(gòu)賦值是一種特殊的語(yǔ)法,它使我們可以將數(shù)組或?qū)ο蟆安鸢敝烈幌盗凶兞恐?,因?yàn)橛袝r(shí)這樣更方便,接下來(lái)通過(guò)本文給大家介紹ES6中的解構(gòu)賦值(數(shù)組,對(duì)象,嵌套,默認(rèn)值),需要的朋友可以參考下2022-11-11javascript 動(dòng)態(tài)加載 css 方法總結(jié)
有時(shí)候我們?cè)谠O(shè)計(jì)網(wǎng)頁(yè)的時(shí)候想動(dòng)態(tài)的加載css文件,并不是將css文件寫死在頁(yè)面中,這時(shí)就可以使用下面方法.2009-07-07Bootstrap 折疊(Collapse)插件用法實(shí)例詳解
這篇文章主要介紹了Bootstrap 折疊(Collapse)插件用法實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2016-06-06javacript replace 正則取字符串中的值并替換【推薦】
replace() 方法用于在字符串中用一些字符替換另一些字符,或替換一個(gè)與正則表達(dá)式匹配的子串。這篇文章主要介紹了javacript replace 正則取字符串中的值并替換,需要的朋友可以參考下2018-09-09