首頁  >  文章  >  web前端  >  js判斷undefined類型,undefined,null, 的區別詳細解析_javascript技巧

js判斷undefined類型,undefined,null, 的區別詳細解析_javascript技巧

WBOY
WBOY原創
2016-05-16 17:09:051289瀏覽

js判斷undefined型

今天使用showModalDialog開啟頁面,傳回值時。當開啟的頁面點選關閉按鈕或直接點擊瀏覽器上的關閉則回傳值是undefined
所以自作聰明判斷  

var reValue=window.showModalDialog("","","");
  if (reValue== undefined){
  alert("undefined");
 }

  alert("undefined");

 }

發現判斷不出來,最後查了一下資料要用typeof
方法:

if (typeof(reValue) == "undefined") {
    alert("undefined");

}  

字串of 回傳的是,有六種可能:"number"、"string"、"boolean"、"object"、"function"、"undefined"
js中undefined,null,NaN的差別


1.型別分析:

js中的資料型態有undefined,boolean,number,string,object等5種,前4種為原始型,第5種為引用型別。
var a1;
var a2 = true;
var a3 = 1;
var a4 = "Hello";
var a5 = new Object();
var a6 = null ;
var a7 = NaN;
var a8 = undefined;
alert(typeof a);    //顯示"undefined"
alert(typeof a1); //顯示"undefined"
alert(typeof a2); //顯示"boolean"
alert(typeof a3); //顯示"number"
alert(typeof a4); //顯示"string"
alert(typeof a5) ; //顯示"object"
alert(typeof a6); //顯示"object"

alert(typeof a7); //顯示"number"

alert(typeof a8); //顯示" undefined"

從上面的程式碼可以看出未定義的值和定義未賦值的為undefined,null是一種特殊的object,NaN是一種特殊的number。
2.比較運算

var a1;         //a1的值為undefined
var a2 = null;
var a3 = NaN;
var a2 = null;
var a3 = NaN;alert(a1 != a2); //顯示"false"
alert(a1 == a3); //顯示"false"
alert(a1 ! = a3); //顯示"true"
alert(a2 == a3); //顯示"false"

alert(a2 != a3); //顯示"true"

alert(a3 == a3); //顯示"false"

alert(a3 != a3); //顯示"true"

從上面的程式碼可以得出結論:(1)undefined與null相等;(2)NaN與任何值都不相等,與自己也不相等。

JavaScript undefined 屬性


定義與用法

undefined 屬性用來存放 JavaScript 的 undefined 值。

文法

undefined

說明

無法使用 for/in 迴圈來列舉 undefined 屬性,也不能用 delete 運算子來刪除它。

undefined 不是常數,可以把它設定為其他值。 當嘗試讀取不存在的物件屬性時也會傳回 undefined。

提示和註解

提示:只能用 === 運算來測試某個值是否是未定義的,因為 == 運算子認為 undefined 值等價於 null。 註解:null 表示無值,而 undefined 表示一個未宣告的變量,或已宣告但沒有賦值的變量,或不存在的物件屬性。

實例

在本例中,我們將偵測兩個變數中未定義的一個:

if (t1===undefined) {document.write("t1 is undefined")}

if (t2===undefined) {document.write("t2 is undefined" )}

輸出:t2 is undefined
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn