Javascript中Null和undefined的簡單理解
前言
在 JavaScript 中有兩種表達(dá)“無”的方式,那就是使用undefined和null。
undefined
如果您創(chuàng)建一個變量并且不對其進(jìn)行任何設(shè)置,它將是undefined. ??
let dog; console.log(dog);

undefined是已經(jīng)創(chuàng)建(變量)但尚未定義(給定值)的東西。
對象的屬性也是如此。
一個不具有任何屬性的person對象。
let person={
}
如果在控制臺中輸入person.dog,它將返回undefined。

為什么?因?yàn)閜erson什么都沒有。這就是undefined的。
當(dāng)嘗試訪問已創(chuàng)建但未賦予值的變量時,就會出現(xiàn)這種情況。
如果在控制臺中輸入test,您會看到返回的錯誤消息說*“test is not defined”*,這意味著您沒有創(chuàng)建名為test的變量.

對于我們上面使用的狗示例,我們已經(jīng)創(chuàng)建了變量,但我們沒有設(shè)置值。這就是區(qū)別。
Null
現(xiàn)在我們將討論null類型。
Null 是空值,而 undefined 是尚未設(shè)置值的變量。
我們將通過一些示例進(jìn)行演示。
在控制臺輸入下面的代碼。
let somethingUndefined; const somethingNull = null;
注意:您不能在不設(shè)置值的情況下使用 const 變量。
somethingUndefined是未定義的,因?yàn)樗鼪]有設(shè)置值,而somethingNull具有 null 的值,它什么都沒有。它們都什么都不是,只是方式不同。
例如,假設(shè)我們有 Cher 和 Teller(他們都是真人),我們將在這樣的對象中表示他們 ??
const zhangsan = { mane: "zhangsan",};
const lisi = { name: "lisi", age: 18,};
lisi.mane = "li";
lisi.age = null;
在此示例中,zhangsan沒有age屬性。
另一方面,我們又將lisi的age設(shè)置為null。
在控制臺中,如果您鍵入,zhangsan.age您將看到返回的 undefined 值。當(dāng)您嘗試lisi.age時,將返回 null 的值。

用一句話總結(jié)兩者的區(qū)別就是:undefined 表示一個變量自然的、最原始的狀態(tài)值,而 null 則表示一個變量被人為的設(shè)置為空對象,而不是原始狀態(tài)。所以,在實(shí)際使用過程中,為了保證變量所代表的語義,不要對一個變量顯式的賦值 undefined,當(dāng)需要釋放一個對象時,直接賦值為 null 即可。
附:實(shí)際應(yīng)用
上面說了那么多,好像除了增加復(fù)雜性之外,并沒有什么實(shí)際的用處。
下面用代碼演示這兩種類型的實(shí)際用法,可以體會不存在和空值具體有什么區(qū)別和用處:
var foo = {a:1, b:2};
console.log(JSON.stringify(foo)); // {"a":1,"b":2}
foo = {...foo, a:null};
console.log(JSON.stringify(foo)); // {"a":null,"b":2}
foo = {...foo, a:undefined};
console.log(JSON.stringify(foo)); // {"b":2}
從上面的代碼可以看到,把一個對象的屬性設(shè)置成undefined后,這個屬性就消失了、不存在了。而設(shè)置成null,這個屬性還是存在,只不過是null值。
如果你想讓對象中某個屬性消失,那么就把它設(shè)置成undefined吧。這也許是undefined和null同時存在的最大的意義。
總結(jié)
到此這篇關(guān)于Javascript中Null和undefined的文章就介紹到這了,更多相關(guān)JS Null和undefined內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
等待指定時間后自動跳轉(zhuǎn)或關(guān)閉當(dāng)前頁面的js代碼
本文為大家詳細(xì)介紹下如何通過js實(shí)現(xiàn)等待指定時間后自動跳轉(zhuǎn)或關(guān)閉當(dāng)前頁面的腳步代碼,感興趣的朋友可以參考下哈,希望對大家有所幫助2013-07-07
JavaScript數(shù)組reduce常見實(shí)例方法
reduce方法在數(shù)組的每個元素上執(zhí)行用戶提供的回調(diào)函數(shù),即"reducer",它傳入對前一個元素進(jìn)行計算的返回值,結(jié)果是單個值,它是在數(shù)組的所有元素上運(yùn)行reducer的結(jié)果,下面這篇文章主要給大家介紹了關(guān)于JavaScript數(shù)組reduce常見實(shí)例方法的相關(guān)資料,需要的朋友可以參考下2022-05-05
JS實(shí)現(xiàn)頁面超時后自動跳轉(zhuǎn)到登陸頁面
這篇文章主要介紹了JS實(shí)現(xiàn)頁面超時后自動跳轉(zhuǎn)到登陸頁面,需要的朋友可以參考下2015-01-01
JS 創(chuàng)建對象的模式實(shí)例小結(jié)
這篇文章主要介紹了JS 創(chuàng)建對象的模式,結(jié)合實(shí)例形式總結(jié)分析了JS 創(chuàng)建對象的各種常用模式,包括工廠模式、構(gòu)造函數(shù)模式、原型模式、組合構(gòu)造和原型模式、動態(tài)原型模式、寄生構(gòu)造函數(shù)模式、穩(wěn)妥構(gòu)造模式等,需要的朋友可以參考下2020-04-04

