javascript
html怎么转换undefined,JavaScript之Undefined详解
Undefined 這個概念聽起來很簡單,不過你知道應該怎樣檢查JavaScript中的變量或屬性是否真的存在嗎? 做這件事最好的方法是什么? 我們如何涵蓋所有的邊界值? 要回答這些問題,首先讓我們來看看究竟什么是undefined......
undefined概述
變量的值被賦予一個類型,JavaScript中有幾個內置的本地類型:Undefined
Null
Boolean
String
Number
Object
Reference
etc…
首先看第一個,內置的Undefined類型只能有一個值,它稱為undefined。 這是一個原始值,只要聲明了變量,就會為其分配此undefined值,直到您以編程的手段為其分配不同的值。
此外,每當函數完成執行并返回一個沒有給定的值時,它默認返回undefined。var foo,
bar = (function() {
// do some stuff
}()),
baz = (function() {
var hello;
return hello;
}());
typeof foo; // undefined
typeof bar; // undefined
typeof baz; // undefined
因此,當聲明一個變量但還未賦值時,它將被賦予undefined值。 我們還應該注意的是:undefined本身是一個在全局范圍內可用的變量/屬性,它的值也是undefined。typeof undefined; // undefined
var foo;
foo === undefined; // true
但是,全局變量undefined并不是保留字,因此它可以被重新定義。 幸運的是,從ECMA 5開始,就不允許重新定義undefined了,但是在以前的版本和舊版瀏覽器中,可以執行以下操作:typeof undefined; // undefined
undefined = 99;
typeof undefined; // number
null到底代表了什么?
先看下面的代碼:null == undefined // true
null !== undefined // true
很多人對此都感到困惑,實際上很簡單。 null和undefined之間唯一真正的關系是:它們在類型強制過程中都判斷為false。
之所以所以 null == undefined // true 是因為 == 沒有執行嚴格的比較,因為在比較類型時使用 !== 更嚴格。 每當您把 null 看作是一個值時,它會始終以編程方式進行指定,并且在默認情況下從不設置。
訪問對象的屬性
當您嘗試使用對象上一個不存在的屬性時,也會得到undefined,如果您把不存在的屬性作為函數使用有時會引發錯誤。var foo = {};
foo.bar; // undefined
foo.bar(); // TypeError
如果您想分辨“有未定義值的屬性”和“根本不存在的屬性”這兩者,應該怎么做呢?
使用typeof 或者 ===都會給你一個undefined的值。
使用in運算符能夠檢查對象中是否存在某個屬性:var foo = {};
// undefined (這樣不好,bar從未在window對象中被聲明過)
typeof foo.bar;
// false (如果您不關心原型鏈,這樣用)
'bar' in foo;
// false (如果你關心原型鏈,就這樣用)
foo.hasOwnProperty('bar');
應該用typeof還是in/hasOwnProperty?
這很顯然。一般來說,如果要測試是一個屬性否存在,那么就用 in/hasOwnProperty,如果要檢查屬性或變量的值,則用 typeof。
通過例子進行總結
檢查變量是否存在:if (typeof foo !== 'undefined') {}
檢查對象上的屬性是否存在,無論是否已經為它分配了值:// 存在于對象上,同時也檢查原型
if ('foo' in bar) {}
// 直接存在于對象上,不檢查原型
if (bar.hasOwnProperty('foo')) {}
檢查對象上是否存在屬性,并且屬性具有值集(真值或假)var bar = {
foo: false
};
if ('foo' in bar && typeof bar.foo !== 'undefined'){
// bar.foo存在,并且它包含以編程方式分配的值
}
總結
以上是生活随笔為你收集整理的html怎么转换undefined,JavaScript之Undefined详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 鸿蒙os终于开始大升级,华为鸿蒙OS终于
- 下一篇: flask html下拉列表,如何使用F