JavaScript null和undefined區(qū)別分析
一時(shí)間不好回答,特別是undefined,因?yàn)檫@涉及到undefined的實(shí)現(xiàn)原理。于是,細(xì)想之后,寫(xiě)下本文,請(qǐng)各位大俠拍磚。
總所周知:null == undefined
但是:null !== undefined
那么這兩者到底有啥區(qū)別呢?
請(qǐng)聽(tīng)俺娓娓道來(lái)...
null
這是一個(gè)對(duì)象,但是為空。因?yàn)槭菍?duì)象,所以 typeof null 返回 'object' 。
null 是 JavaScript 保留關(guān)鍵字。
null 參與數(shù)值運(yùn)算時(shí)其值會(huì)自動(dòng)轉(zhuǎn)換為 0 ,因此,下列表達(dá)式計(jì)算后會(huì)得到正確的數(shù)值:
表達(dá)式:123 + null 結(jié)果值:123
表達(dá)式:123 * null 結(jié)果值:0
undefined
undefined是全局對(duì)象(window)的一個(gè)特殊屬性,其值是未定義的。但 typeof undefined 返回 'undefined' 。
雖然undefined是有特殊含義的,但它確實(shí)是一個(gè)屬性,而且是全局對(duì)象(window)的屬性。請(qǐng)看下面的代碼:
alert('undefined' in window);//輸出:true
var anObj = {};
alert('undefined' in anObj); //輸出:false
從中可以看出,undefined是window對(duì)象的一個(gè)屬性,但卻不是anObj對(duì)象的一個(gè)屬性。
注意:盡管undefined是有特殊含義的屬性,但卻不是JavaScript的保留關(guān)鍵字。
undefined參與任何數(shù)值計(jì)算時(shí),其結(jié)果一定是NaN。
隨便說(shuō)一下,NaN是全局對(duì)象(window)的另一個(gè)特殊屬性,Infinity也是。這些特殊屬性都不是JavaScript的保留關(guān)鍵字!
提高undefined性能
當(dāng)我們?cè)诔绦蛑惺褂胾ndefined值時(shí),實(shí)際上使用的是window對(duì)象的undefined屬性。
同樣,當(dāng)我們定義一個(gè)變量但未賦予其初始值,例如:
var aValue;
這時(shí),JavaScript在所謂的預(yù)編譯時(shí)會(huì)將其初始值設(shè)置為對(duì)window.undefined屬性的引用,
于是,當(dāng)我們將一個(gè)變量或值與undefined比較時(shí),實(shí)際上是與window對(duì)象的undefined屬性比較。這個(gè)比較過(guò)程中,JavaScript會(huì)搜索window對(duì)象名叫‘undefined'的屬性,然后再比較兩個(gè)操作數(shù)的引用指針是否相同。
由于window對(duì)象的屬性值是非常多的,在每一次與undefined的比較中,搜索window對(duì)象的undefined屬性都會(huì)花費(fèi)時(shí) 間。在需要頻繁與undefined進(jìn)行比較的函數(shù)中,這可能會(huì)是一個(gè)性能問(wèn)題點(diǎn)。因此,在這種情況下,我們可以自行定義一個(gè)局部的undefined變 量,來(lái)加快對(duì)undefined的比較速度。例如:
function anyFunc() {
var undefined;
//自定義局部undefined變量
if(x == undefined)
//作用域上的引用比較
while(y != undefined)
//作用域上的引用比較
};
其中,定義undefined局部變量時(shí),其初始值會(huì)是對(duì)window.undefined屬性值的引用。新定義的局部undefined變 量存在與該函數(shù)的作用域上。在隨后的比較操作中,JavaScript代碼的書(shū)寫(xiě)方式?jīng)]有任何的改變,但比較速度卻很快。因?yàn)樽饔糜蛏系淖兞繑?shù)量會(huì)遠(yuǎn)遠(yuǎn)少 于window對(duì)象的屬性,搜索變量的速度會(huì)極大提高。
這就是許多前端JS框架為什么常常要自己定義一個(gè)局部undefined變量的原因!
- js判斷undefined類(lèi)型,undefined,null, 的區(qū)別詳細(xì)解析
- JavaScript Undefined,Null類(lèi)型和NaN值區(qū)別
- JS基礎(chǔ)之undefined與null的區(qū)別分析
- Javascript 中 null、NaN和undefined的區(qū)別總結(jié)
- javascript中的undefined 與 null 的區(qū)別 補(bǔ)充篇
- undefined==null引發(fā)的兩者區(qū)別與聯(lián)系
- 詳解JavaScript中undefined與null的區(qū)別
- js中 關(guān)于undefined和null的區(qū)別介紹
- JavaScript中undefined和null的區(qū)別
- 一文讓你徹底弄懂js中undefined和null的區(qū)別
相關(guān)文章
JS是否可以跨文件同時(shí)控制多個(gè)iframe頁(yè)面的應(yīng)用技巧
這篇文章給大家詳細(xì)介紹了JS是否可以跨文件同時(shí)控制多個(gè)iframe頁(yè)面的應(yīng)用技巧,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2007-12-12typescript環(huán)境安裝并開(kāi)啟VSCode自動(dòng)監(jiān)視編譯ts文件為js文件
這篇文章主要介紹了安裝typescript環(huán)境并開(kāi)啟VSCode自動(dòng)監(jiān)視編譯ts文件為js文件,本文教大家最基礎(chǔ)的安裝和配置自動(dòng)監(jiān)視ts文件編譯成js文件,需要的朋友可以參考下2022-06-06js實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊文本框自動(dòng)選中內(nèi)容的方法
這篇文章主要介紹了js實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊文本框自動(dòng)選中內(nèi)容的方法,涉及javascript鼠標(biāo)點(diǎn)擊事件onClick及選擇事件select的使用技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-08-08JavaScript實(shí)現(xiàn)簡(jiǎn)單圖片滾動(dòng)附源碼下載
JavaScript實(shí)現(xiàn)簡(jiǎn)單圖片滾動(dòng),9張圖告訴你,C羅欲哭無(wú)淚,另附源碼下載,方便學(xué)習(xí)2014-06-06JS高級(jí)拖動(dòng)技術(shù) setCapture,releaseCapture
setCapture 的意思就是設(shè)置一個(gè)對(duì)象的方法被觸發(fā)的范圍,或者作用域。2011-07-07如何利用原生JS實(shí)現(xiàn)圖片預(yù)覽加上傳(前后端交互)
在做網(wǎng)站系統(tǒng)時(shí)經(jīng)常會(huì)用到圖片上傳功能,用戶往往希望能看到自己上傳的圖片的樣子,下面這篇文章主要給大家介紹了關(guān)于如何利用原生JS實(shí)現(xiàn)圖片預(yù)覽加上傳,需要的朋友可以參考下2022-01-01