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; alert(a1 == a2); //显示"true" 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 表示一個未宣告的變量,或已宣告但沒有賦值的變量,或不存在的物件屬性。
實例
在本例中,我們將偵測兩個變數中未定義的一個:
<script type="text/javascript"> var t1="" var t2 if (t1===undefined) {document.write("t1 is undefined")} if (t2===undefined) {document.write("t2 is undefined")} </script>
輸出:
t2 is undefined
判斷undefined:
<span style="font-size: small;">var tmp = undefined; if (typeof(tmp) == "undefined"){ alert("undefined"); }</span>
判斷null:
<span style="font-size: small;">var tmp = null; if (!tmp && typeof(tmp)!="undefined" && tmp!=0){ alert("null"); } </span>
判斷NaN:
<span style="font-size: small;">var tmp = 0/0; if(isNaN(tmp)){ alert("NaN"); }</span>
#說明:如果將NaN 與任何值(包括其自身)相較之下得到的結果皆是false,所以要判斷某個值是否為NaN,不能使用== 或=== 運算子。
提示:isNaN() 函數通常用於偵測 parseFloat() 和 parseInt() 的結果,以判斷它們表示的是否為合法的數字。當然也可以用 isNaN() 函數來偵測算數錯誤,例如用 0 作除數的情況。
以上是javascript中undefined,null, NaN等的區別用法實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!