中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript中undefined與null有什么區別

發布時間:2021-11-20 11:55:08 來源:億速云 閱讀:124 作者:iii 欄目:開發技術

這篇文章主要介紹“JavaScript中undefined與null有什么區別”,在日常操作中,相信很多人在JavaScript中undefined與null有什么區別問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”JavaScript中undefined與null有什么區別”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

一、相似性

在JavaScript中,將一個變量賦值為undefined或null,老實說,幾乎沒區別。

var a = undefined;var a = null;

上面代碼中,a變量分別被賦值為undefined和null,這兩種寫法幾乎等價。

undefined和null在if語句中,都會被自動轉為false,相等運算符甚至直接報告兩者相等。

if (!undefined)     console.log('undefined is false');// undefined is falseif (!null)     console.log('null is false');// null is falseundefined == null// true

上面代碼說明,兩者的行為是何等相似!

既然undefined和null的含義與用法都差不多,為什么要同時設置兩個這樣的值,這不是無端增加JavaScript的復雜度,令初學者困擾嗎?Google公司開發的JavaScript語言的替代品Dart語言,就明確規定只有null,沒有undefined!

二、歷史原因

最近,我在讀新書《Speaking JavaScript》時,意外發現了這個問題的答案!

原來,這與JavaScript的歷史有關。1995年JavaScript誕生時,最初像Java一樣,只設置了null作為表示"無"的值。

根據C語言的傳統,null被設計成可以自動轉為0。

Number(null)// 05 + null// 5

但是,JavaScript的設計者Brendan Eich,覺得這樣做還不夠,有兩個原因。

首先,null像在Java里一樣,被當成一個對象。但是,JavaScript的數據類型分成原始類型(primitive)和合成類型(complex)兩大類,Brendan Eich覺得表示"無"的值最好不是對象。

其次,JavaScript的最初版本沒有包括錯誤處理機制,發生數據類型不匹配時,往往是自動轉換類型或者默默地失敗。Brendan Eich覺得,如果null自動轉為0,很不容易發現錯誤。

因此,Brendan Eich又設計了一個undefined。

三、最初設計

JavaScript的最初版本是這樣區分的:null是一個表示"無"的對象,轉為數值時為0;undefined是一個表示"無"的原始值,轉為數值時為NaN。

Number(undefined)// NaN5 + undefined// NaN

四、目前的用法

但是,上面這樣的區分,在實踐中很快就被證明不可行。目前,null和undefined基本是同義的,只有一些細微的差別。

null表示"沒有對象",即該處不應該有值。典型用法是:

(1) 作為函數的參數,表示該函數的參數不是對象。

(2) 作為對象原型鏈的終點。

Object.getPrototypeOf(Object.prototype)// null

undefined表示"缺少值",就是此處應該有一個值,但是還沒有定義。典型用法是:

(1)變量被聲明了,但沒有賦值時,就等于undefined。

(2) 調用函數時,應該提供的參數沒有提供,該參數等于undefined。

(3)對象沒有賦值的屬性,該屬性的值為undefined。

(4)函數沒有返回值時,默認返回undefined。

var i;i // undefinedfunction f(x){console.log(x)}f() // undefinedvar  o = new Object();o.p // undefinedvar x = f();x // undefined

到此,關于“JavaScript中undefined與null有什么區別”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

堆龙德庆县| 漠河县| 林甸县| 贺州市| 镇康县| 兴宁市| 赣州市| 澎湖县| 报价| 贺州市| 长泰县| 高阳县| 兴海县| 连平县| 昌江| 东平县| 呈贡县| 宜春市| 新闻| 巴彦淖尔市| 清苑县| 龙泉市| 咸丰县| 荣昌县| 田阳县| 广东省| 广饶县| 漠河县| 四子王旗| 故城县| 大同县| 广西| 南投县| 屯昌县| 亚东县| 赤壁市| 古田县| 景东| 招远市| 如东县| 深水埗区|