摘要:因此,當(dāng)聲明一個(gè)變量但還未賦值時(shí),它將被賦予值。和之間唯一真正的關(guān)系是它們在類型強(qiáng)制過程中都判斷為。之所以所以是因?yàn)闆]有執(zhí)行嚴(yán)格的比較,因?yàn)樵诒容^類型時(shí)使用更嚴(yán)格。
原文:http://davidshariff.com/blog/...
翻譯:瘋狂的技術(shù)宅
本文首發(fā)微信公眾號:jingchengyideng
歡迎關(guān)注,每天都給你推送新鮮的前端技術(shù)文章
Undefined 這個(gè)概念聽起來很簡單,不過你知道應(yīng)該怎樣檢查JavaScript中的變量或?qū)傩允欠裾娴拇嬖趩幔?做這件事最好的方法是什么? 我們?nèi)绾魏w所有的邊界值? 要回答這些問題,首先讓我們來看看究竟什么是undefined......
undefined概述變量的值被賦予一個(gè)類型,JavaScript中有幾個(gè)內(nèi)置的本地類型:
Undefined
Null
Boolean
String
Number
Object
Reference
etc…
首先看第一個(gè),內(nèi)置的Undefined類型只能有一個(gè)值,它稱為undefined。 這是一個(gè)原始值,只要聲明了變量,就會為其分配此undefined值,直到您以編程的手段為其分配不同的值。
此外,每當(dāng)函數(shù)完成執(zhí)行并返回一個(gè)沒有給定的值時(shí),它默認(rèn)返回undefined。
var foo, bar = (function() { // do some stuff }()), baz = (function() { var hello; return hello; }()); typeof foo; // undefined typeof bar; // undefined typeof baz; // undefined
因此,當(dāng)聲明一個(gè)變量但還未賦值時(shí),它將被賦予undefined值。 我們還應(yīng)該注意的是:undefined本身是一個(gè)在全局范圍內(nèi)可用的變量/屬性,它的值也是undefined。
typeof undefined; // undefined var foo; foo === undefined; // true
但是,全局變量undefined并不是保留字,因此它可以被重新定義。 幸運(yùn)的是,從ECMA 5開始,就不允許重新定義undefined了,但是在以前的版本和舊版瀏覽器中,可以執(zhí)行以下操作:
typeof undefined; // undefined undefined = 99; typeof undefined; // numbernull到底代表了什么?
先看下面的代碼:
null == undefined // true null !== undefined // true
很多人對此都感到困惑,實(shí)際上很簡單。 null和undefined之間唯一真正的關(guān)系是:它們在類型強(qiáng)制過程中都判斷為false。
之所以所以 null == undefined // true 是因?yàn)?== 沒有執(zhí)行嚴(yán)格的比較,因?yàn)樵诒容^類型時(shí)使用 !== 更嚴(yán)格。 每當(dāng)您把 null 看作是一個(gè)值時(shí),它會始終以編程方式進(jìn)行指定,并且在默認(rèn)情況下從不設(shè)置。
訪問對象的屬性當(dāng)您嘗試使用對象上一個(gè)不存在的屬性時(shí),也會得到undefined,如果您把不存在的屬性作為函數(shù)使用有時(shí)會引發(fā)錯(cuò)誤。
var foo = {}; foo.bar; // undefined foo.bar(); // TypeError
如果您想分辨“有未定義值的屬性”和“根本不存在的屬性”這兩者,應(yīng)該怎么做呢?
使用typeof 或者 ===都會給你一個(gè)undefined的值。
使用in運(yùn)算符能夠檢查對象中是否存在某個(gè)屬性:
var foo = {}; // undefined (這樣不好,bar從未在window對象中被聲明過) typeof foo.bar; // false (如果您不關(guān)心原型鏈,這樣用) "bar" in foo; // false (如果你關(guān)心原型鏈,就這樣用) foo.hasOwnProperty("bar");應(yīng)該用typeof還是in/hasOwnProperty?
這很顯然。一般來說,如果要測試是一個(gè)屬性否存在,那么就用 in/hasOwnProperty,如果要檢查屬性或變量的值,則用 typeof。
通過例子進(jìn)行總結(jié)檢查變量是否存在:
if (typeof foo !== "undefined") {}
檢查對象上的屬性是否存在,無論是否已經(jīng)為它分配了值:
// 存在于對象上,同時(shí)也檢查原型 if ("foo" in bar) {} // 直接存在于對象上,不檢查原型 if (bar.hasOwnProperty("foo")) {}
檢查對象上是否存在屬性,并且屬性具有值集(真值或假)
var bar = { foo: false }; if ("foo" in bar && typeof bar.foo !== "undefined"){ // bar.foo存在,并且它包含以編程方式分配的值 }本文首發(fā)微信公眾號:jingchengyideng
歡迎掃描二維碼關(guān)注公眾號,每天都給你推送新鮮的前端技術(shù)文章
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/108897.html
摘要:類型的實(shí)例首先要理解的含義是例子的意思,實(shí)際上是判斷是否是的一個(gè)實(shí)例。 數(shù)據(jù)類型深入理解 數(shù)據(jù)類型分類 基本(值)類型(5種) String:任意字符串 Number:任意的數(shù)字 boolean:true/false null:null undefined:undefined 對象(引用)類型(3種) Object:任意對象 Array:一種特別的對象(數(shù)值下...
摘要:變量提升原理引擎的工作方式是先解析代碼,獲取所有被聲明的變量然后在運(yùn)行。代碼自上而下執(zhí)行之前,瀏覽器首先會把所有帶關(guān)鍵詞的進(jìn)行提前聲明或者定義,這種預(yù)先處理機(jī)制稱之為變量提升。 變量提升 原理:JS引擎的工作方式是先解析代碼,獲取所有被聲明的變量;然后在運(yùn)行。JS代碼自上而下執(zhí)行之前,瀏覽器首先會把所有帶 VAR/FUNCTION 關(guān)鍵詞的進(jìn)行提前 聲明 或者 定義 ,這種預(yù)先處理機(jī)制...
摘要:的解析與執(zhí)行過程第一個(gè)彈出函數(shù)體第二個(gè)彈出函數(shù)體第三個(gè)彈出第四個(gè)彈出第五個(gè)彈出最后一行報(bào)錯(cuò)執(zhí)行分析第行,沒有關(guān)鍵字,不解析第行,遇到關(guān)鍵字,解析到全局的頭部第行,沒有關(guān)鍵字,不解析第行,遇到關(guān)鍵字,解析到全局的頭部第行,沒有關(guān)鍵 js的解析與執(zhí)行過程 showImg(https://segmentfault.com/img/bVbe2UQ?w=1744&h=782); alert(a)...
摘要:方法直接在一個(gè)對象上定義新的屬性或修改現(xiàn)有屬性,并返回該對象。默認(rèn)為當(dāng)且僅當(dāng)在枚舉相應(yīng)對象上的屬性時(shí)該屬性顯現(xiàn)。函數(shù)返回值將被用作屬性的值。默認(rèn)為返回值傳遞給函數(shù)的對象。 Object.defineProperties() Object.defineProperties() 方法直接在一個(gè)對象上定義新的屬性或修改現(xiàn)有屬性,并返回該對象。 語法 Object.defineProperti...
摘要:本文將根據(jù)以下章節(jié)分別梳理每個(gè)鉤子同步鉤子首先安裝是簡單的同步鉤子,它很類似于發(fā)布訂閱。至此,我們把的所有同步鉤子都解析完畢異步鉤子比同步鉤子麻煩些,我們會在下一章節(jié)開始解析異步的鉤子傳送門深入理解核心模塊鉤子異步版代碼 記錄下自己在前端路上爬坑的經(jīng)歷 加深印象,正文開始~ tapable是webpack的核心依賴庫 想要讀懂webpack源碼 就必須首先熟悉tapableok.下面是...
閱讀 700·2023-04-25 19:53
閱讀 4294·2021-09-22 15:13
閱讀 2578·2019-08-30 10:56
閱讀 1334·2019-08-29 16:27
閱讀 2944·2019-08-29 14:00
閱讀 2423·2019-08-26 13:56
閱讀 445·2019-08-26 13:29
閱讀 1623·2019-08-26 11:31