Javascript中3個(gè)需要注意的運(yùn)算符
平時(shí)寫(xiě)慣了C#,所以會(huì)覺(jué)得什么樣的運(yùn)算符就應(yīng)該做什么樣的運(yùn)算,但是有一天你的習(xí)慣被其他語(yǔ)言顛覆了,不知道是不是有一股強(qiáng)大的好奇
心,剛好在js中,我的這種習(xí)慣就被顛覆了,下面就看看哪些運(yùn)算符顛覆了我的三觀。
一:==運(yùn)算符
==運(yùn)算符之所以可以顛覆,可以從下面幾個(gè)例子中看出來(lái)。
<1> "10"==10 ?
如果這要是放在C#里面,編譯器會(huì)毫不客氣的告訴你,王八羔子,類型都不同,你比個(gè)毛線啊。。。但是在JS里面又會(huì)是怎樣呢?
從上圖中,你可以看到,不管你好奇不好奇,答案就在那里,可能有人就要問(wèn),到底是10轉(zhuǎn)化成了“10”,還是“10”被轉(zhuǎn)化成了10,所以這個(gè)也
是我一直吐槽的地方,如果是C#,你還可以看看IL里面到底怎么處理的,而JS里面你什么都看不到,只能聽(tīng)教科書(shū)上的一面之詞,無(wú)法眼見(jiàn)為實(shí)。
所以除了記住就是記住了,我只能說(shuō)是字符串”10“轉(zhuǎn)換成了10,然后進(jìn)行整形比較的。
<2>true==1 ?
這個(gè)問(wèn)題稍微想想還能理解,其實(shí)在C#的IL中,也是將true和false相應(yīng)的轉(zhuǎn)化為1和0,所以js在判斷時(shí)會(huì)將true轉(zhuǎn)化為1,再進(jìn)行整形比較,這
個(gè)現(xiàn)象我覺(jué)得不怎么稀奇,記住就好。
<3> {valueOf:function(){return "10"}}==10?
這個(gè)問(wèn)題也是蠻奇葩的,對(duì)象居然還可以和int類型相比較?但是在JS中卻真的可以做到,原理是這樣的,如果一個(gè)對(duì)象和int/string比較的話,
js內(nèi)部會(huì)優(yōu)先調(diào)用valueOf方法,也就是將對(duì)象數(shù)值化,其實(shí)這里好玩的地方就是我們自定義的valueOf重寫(xiě)了父類的valueOf方法,所以上面
的例子就是判斷“10”==10?。
這里還要PS一下,如果你的類中沒(méi)有定義valueOf方法的話,js內(nèi)部引擎還會(huì)再去找toString()方法,如果有則執(zhí)行。
不知道當(dāng)你接觸到這些新用法的時(shí)候,是不是覺(jué)得有點(diǎn)慌亂,好像有種亂七八糟的感覺(jué)?如果你很怕程序有潛在的bug,那么為了保險(xiǎn)起見(jiàn),
轉(zhuǎn)化為同一數(shù)據(jù)類型來(lái)比較吧,當(dāng)然在js里面還有一個(gè)===運(yùn)算符可以說(shuō)跟C#里面的邏輯運(yùn)算符算是最接近的,這個(gè)多出來(lái)的“=”就是在
“==”的基礎(chǔ)上再判斷類型是否相等?就比如:
二:&&和||運(yùn)算符
這兩個(gè)運(yùn)算符也是蠻奇葩的,在我們的思維習(xí)慣里面,這兩個(gè)運(yùn)算符兩邊就應(yīng)該都是bool類型,但是在JS里面這些定義會(huì)被徹底顛覆,正是這些新規(guī)則,所以我們可以完成很多新花樣,比如在jquery的源碼中,可以到處都能找到這樣的痕跡。
從圖中我們看到了這么一句,bup=b && b.parentNode,你能理解這句話的意思嗎?其實(shí)它的意思是先判斷b是否存在,如果b不存在,那
可能b就是undefined,null,0 或者NaN,如果b存在,那么就返回m.parentNode,就這么好玩,如果你用C#的話,就少不了幾個(gè)if條件了,
也算是簡(jiǎn)化代碼吧,然后再看看||操作,這個(gè)簡(jiǎn)直在源碼里面可以用泛濫來(lái)形容了,不過(guò)乍一看,特別像是C#中的可空運(yùn)算符,所以親切感倍
增,下面就拿ret=results||[]來(lái)說(shuō),如果results有值,那么ret=results,如果results為null,undefined,NaN或者0,那么result=[],就
這樣的任性,省去了程序員很多if判斷,最后要補(bǔ)充一句,其實(shí)就像C#的IL中一樣,只是JS底層給我們做了if判斷。
相關(guān)文章
js時(shí)間比較 js計(jì)算時(shí)間差的簡(jiǎn)單實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇js時(shí)間比較 js計(jì)算時(shí)間差的簡(jiǎn)單實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08IE event.srcElement和FF event.target 功能比較
可以捕獲當(dāng)前事件作用的對(duì)象,如event.srcElement.tagName可以捕獲活動(dòng)標(biāo)記名稱。2010-03-03微信小程序自定義tabbar欄實(shí)現(xiàn)過(guò)程講解
tabBar相對(duì)而言用的還是比較多的,但是用起來(lái)并沒(méi)有難,下面這篇文章主要給大家介紹了關(guān)于微信小程序全局配置之tabBar的相關(guān)資料,文中通過(guò)圖文以及示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02javascript中for...of和for..in循環(huán)的區(qū)別
JS中循環(huán)語(yǔ)句眾多,你是否也有用的時(shí)候突然不知道用哪個(gè)的經(jīng)歷,本文主要介紹了javascript中for...of和for..in循環(huán)的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08Bootstrap fileinput文件上傳預(yù)覽插件使用詳解
這篇文章主要為大家詳細(xì)介紹了Bootstrap fileinput文件上傳預(yù)覽插件的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05