Javascript typeof與instanceof的區(qū)別
JavaScript 中 typeof 和 instanceof 常用來判斷一個變量是否為空,或者是什么類型的。但它們之間還是有區(qū)別的:
typeof
typeof 是一個一元運算,放在一個運算數(shù)之前,運算數(shù)可以是任意類型。
它返回值是一個字符串,該字符串說明運算數(shù)的類型。typeof 一般只能返回如下幾個結果:
number,boolean,string,function,object,undefined。我們可以使用 typeof 來獲取一個變量是否存在,如 if(typeof a!="undefined"){alert("ok")},而不要去使用 if(a) 因為如果 a 不存在(未聲明)則會出錯,對于 Array,Null 等特殊對象使用 typeof 一律返回 object,這正是 typeof 的局限性。
instanceof
instance:實例,例子
a instanceof b?alert("true"):alert("false"); //a是b的實例?真:假
instanceof 用于判斷一個變量是否某個對象的實例,如 var a=new Array();alert(a instanceof Array); 會返回 true,同時 alert(a instanceof Object) 也會返回 true;這是因為 Array 是 object 的子類。再如:function test(){};var a=new test();alert(a instanceof test) 會返回
談到 instanceof 我們要多插入一個問題,就是 function 的 arguments,我們大家也許都認為 arguments 是一個 Array,但如果使用 instaceof 去測試會發(fā)現(xiàn) arguments 不是一個 Array 對象,盡管看起來很像。
另外:
測試 var a=new Array();if (a instanceof Object) alert('Y');else alert('N');
得'Y'
但 if (window instanceof Object) alert('Y');else alert('N');
得'N'
所以,這里的 instanceof 測試的 object 是指 js 語法中的 object,不是指 dom 模型對象。
使用 typeof 會有些區(qū)別
alert(typeof(window)) 會得 object
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- JavaScript中isPrototypeOf函數(shù)
- JS中的hasOwnProperty()和isPrototypeOf()屬性實例詳解
- JavaScript中isPrototypeOf函數(shù)作用和使用實例
- js中的hasOwnProperty和isPrototypeOf方法使用實例
- JavaScript isPrototypeOf和hasOwnProperty使用區(qū)別
- java 中的instanceof用法詳解及instanceof是什么意思(推薦)
- JavaScript的instanceof運算符學習教程
- JavaScript中instanceof運算符的使用示例
- JavaScript中instanceof運算符的用法總結
- JavaScript instanceof 的使用方法示例介紹
- JavaScript中isPrototypeOf、instanceof和hasOwnProperty函數(shù)的用法詳解
相關文章
JavaScript中關于indexOf的使用方法與問題小結
indexOf方法的作用是:根據(jù)給定參數(shù)x返回目標字符串(可以看成字符的數(shù)組)或數(shù)組中與x相等的項的索引。2010-08-08javascript prototype原型詳解(比較基礎)
prototype原型是javascript中特別重要的概念,屬于必須要掌握,如果沒有良好的掌握的話,進一步用好或者學好js基本是不可能的實現(xiàn)的事情,并且此概念稍有難度,可能對于初次接觸的朋友來說有點困難,下面就通過代碼實例簡單介紹一下prototype原型的用法2016-12-12Javascript代碼在頁面加載時的執(zhí)行順序介紹
Javascript代碼在頁面加載時的執(zhí)行順序介紹,需要的朋友可以參考一下2013-05-05