?前言?】
? ? ? ?從踏入IT行業(yè)開始颁虐,我就發(fā)現(xiàn)技術(shù)人員寫博客很有必要。如果不寫博客卧须,時間久了就像好比天天在外面建房子的人另绩,沒有一個自己的房子一樣瞬痘。不管學習緊不緊,工作忙不忙板熊,多動手進行梳理總結(jié),一方面是為了以后對某一些技術(shù)點不熟悉的時候有個地方可以快速地讓你豁然開朗察绷,另一方面也能把你是說得所想分享給別人干签,結(jié)交更多同行的人。好拆撼,下面步入正題容劳。
【?正文?】
? ? ? ?開始我覺得以這個為題寫一篇博文有點沒必要,畢竟not defined闸度、undefined竭贩、null以及NaN這幾個概念在實際開發(fā)中會經(jīng)常遇到,特別是初期開發(fā)莺禁,我們也大致明白它們代表的意思留量。不過后來考慮了一下其實有很多東西是值得我們挖掘的,所以抽空寫了這篇文章哟冬。
第一:not defined
演示代碼:
<span style="font-size:12px;"><span style="font-family:Microsoft YaHei;"><script type="text/javascript">
? ? alert(a);
</script></span></span>
執(zhí)行結(jié)果:報錯并提示:Uncaught ReferenceError: a is not defined楼熄,如圖:
個人理解:not defined可以翻譯為 未定義的。上面代碼中的a沒有被定義浩峡。所以會報錯并提示not defined可岂。
第二:undefined
演示代碼:
<span style="font-family:Microsoft YaHei;font-size:12px;"><script type="text/javascript">
? ? var a;
? ? alert(a);
</script></span>
或者
<span style="font-family:Microsoft YaHei;font-size:12px;"><script type="text/javascript">
? ? var a=undefined;
? ? alert(a);
</script></span>
或者
<span style="font-family:Microsoft YaHei;font-size:12px;"><script type="text/javascript">
? var a={};
? alert(a);
</script></span></span>
執(zhí)行結(jié)果:上面三段代碼執(zhí)行結(jié)果一樣:不會報錯,會打印出undefined翰灾,如圖:
個人理解:上面出現(xiàn)undefined的三種情況缕粹,
第一是變量被聲明了,但沒有賦值纸淮;
第二是手工賦值為undefined平斩,undefined只是一個值;
第三是一個不存在的對象成員為undefined萎馅。
注意:undefined除了手工賦值之外双戳,其他情況都可以翻譯成:不明確的,也就是不知道用來干嘛的糜芳,表示缺少值飒货,就是某個地方應該有一個值,但是還沒有初始化峭竣。undefined?的優(yōu)點在于正常使用有此值的變量不會拋出異常塘辅。
第三:null
演示代碼:
<span style="font-family:Microsoft YaHei;font-size:12px;"><script type="text/javascript">
? var a=document.getElementById("main");
? alert(a);
</script></span>
執(zhí)行結(jié)果:不會報錯,會打印出null皆撩,如圖:
個人理解:上面的代碼中如果實際上沒有id為main的元素扣墩,a則是null哲银,所以null是真正不存在的東西。另外null是一個只有一個值的特殊類型呻惕。表示一個空對象引用荆责,用typeof檢測返回是object。第二種的undefined是派生自null亚脆,所以有undefined==null做院。
第四:NaN
演示代碼:
<span style="font-family:Microsoft YaHei;font-size:12px;"><script type="text/javascript">
? var a;
? alert(a*2);
</script></span>
執(zhí)行結(jié)果:不會報錯,會打印出NaN濒持,如圖:
個人理解:NaN是"Not a Number " 的簡寫键耕,從字面上看為不是數(shù)字的意思,當運算無法返回正確的數(shù)值時柑营,就會返回NaN值屈雄。也可以理解一下W3C給出的定義和用法:NaN 屬性是代表非數(shù)字值的特殊值。該屬性用于指示某個值不是數(shù)字官套【颇蹋可以把 Number 對象設(shè)置為該值,來指示其不是數(shù)字值奶赔。
null是一種特殊的object讥蟆;NaN是一種特殊的number。?
【?補充擴展?】
深入談?wù)剈ndefined與null纺阔,以下內(nèi)容部分參考自網(wǎng)絡(luò)瘸彤。
大多數(shù)計算機語言,有且僅有一個表示"無"的值笛钝,比如质况,C語言的NULL,Java語言的null玻靡,Python語言的None结榄,Ruby語言的nil。有點奇怪的是囤捻,JavaScript語言居然有兩個表示"無"的值:undefined和null臼朗。這是為什么?
在JavaScript中蝎土,將一個變量賦值為undefined或null视哑,老實說,幾乎沒區(qū)別誊涯。
<span style="font-family:Microsoft YaHei;font-size:12px;"><script type="text/javascript">
? var a=undefined;
? var a=null;
</script></span>
《Speaking JavaScript》這本書中有講到上面的這個問題:JavaScript語言為什么有兩個表示"無"的值挡毅。
1995年JavaScript誕生時,最初像Java一樣暴构,只設(shè)置了null作為表示"無"的值跪呈,但是段磨,JavaScript的設(shè)計者Brendan Eich,覺得這樣做還不夠耗绿。第一:null像在Java里一樣苹支,被當成一個對象。但是误阻,JavaScript的數(shù)據(jù)類型分成原始類型(primitive)和合成類型(complex)兩大類沐序,Brendan Eich覺得表示"無"的值最好不是對象。第二:其次堕绩,JavaScript的最初版本沒有包括錯誤處理機制,發(fā)生數(shù)據(jù)類型不匹配時邑时,往往是自動轉(zhuǎn)換類型或者默默地失敗奴紧。Brendan Eich覺得,如果null自動轉(zhuǎn)為0晶丘,很不容易發(fā)現(xiàn)錯誤黍氮。因此,Brendan Eich又設(shè)計了一個undefined浅浮。
null表示"沒有對象"沫浆,即該處不應該有值;undefined表示"缺少值"滚秩,就是此處應該有一個值专执,但是還沒有初始化。