javascript instanceof 與typeof使用說明
更新時間:2010年01月11日 00:07:20 作者:
instanceof和typeof都能用來判斷一個變量是否為空或是什么類型的變量。
typeof用以獲取一個變量的類型,typeof一般只能返回如下幾個結(jié)果:number,boolean,string,function,object,undefined。我們可以使用typeof來獲取一個變量是否存在,如
if(typeof a != "undefined"){},而不要去使用if(a)因為如果a不存在(未聲明)則會出錯,對于Array,Null等特殊對象使用typeof一律返回object,這正是typeof的局限性。
如果我們希望獲取一個對象是否是數(shù)組,或判斷某個變量是否是某個對象的實例則要選擇使用instanceof。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)會返回true。
談到instanceof我們要多插入一個問題,就是function的arguments,我們大家也許都認(rèn)為arguments是一個Array,但如果使用instaceof去測試會發(fā)現(xiàn)arguments不是一個Array對象,盡管看起來很像。
JavaScript中instanceof運算符是返回一個 Boolean 值,指出對象是否是特定類的一個實例。
使用方法:
result = object instanceof class
其中result是必選項。任意變量。
object是必選項。任意對象表達(dá)式。
class是必選項。任意已定義的對象類。
說明
如果 object 是 class 的一個實例,則 instanceof 運算符返回 true。如果 object 不是指定類的一個實例,或者 object 是 null,則返回 false。
JavaScript中instanceof運算符
下面的例子舉例說明了 instanceof 運算符的用法。
function objTest(obj){
var i, t, s = ""; // 創(chuàng)建變量。
t = new Array(); // 創(chuàng)建一個數(shù)組。
t["Date"] = Date; // 填充數(shù)組。
t["Object"] = Object;
t["Array"] = Array;
for (i in t)
{
if (obj instanceof t[i]) // 檢查 obj 的類。
{
s += "obj is an instance of " + i + "\n";
}
else
{
s += "obj is not an instance of " + i + "\n";
}
}
return(s); // 返回字符串。
}
var obj = new Date();
response.write(objTest(obj));
if(typeof a != "undefined"){},而不要去使用if(a)因為如果a不存在(未聲明)則會出錯,對于Array,Null等特殊對象使用typeof一律返回object,這正是typeof的局限性。
如果我們希望獲取一個對象是否是數(shù)組,或判斷某個變量是否是某個對象的實例則要選擇使用instanceof。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)會返回true。
談到instanceof我們要多插入一個問題,就是function的arguments,我們大家也許都認(rèn)為arguments是一個Array,但如果使用instaceof去測試會發(fā)現(xiàn)arguments不是一個Array對象,盡管看起來很像。
JavaScript中instanceof運算符是返回一個 Boolean 值,指出對象是否是特定類的一個實例。
使用方法:
result = object instanceof class
其中result是必選項。任意變量。
object是必選項。任意對象表達(dá)式。
class是必選項。任意已定義的對象類。
說明
如果 object 是 class 的一個實例,則 instanceof 運算符返回 true。如果 object 不是指定類的一個實例,或者 object 是 null,則返回 false。
JavaScript中instanceof運算符
下面的例子舉例說明了 instanceof 運算符的用法。
復(fù)制代碼 代碼如下:
function objTest(obj){
var i, t, s = ""; // 創(chuàng)建變量。
t = new Array(); // 創(chuàng)建一個數(shù)組。
t["Date"] = Date; // 填充數(shù)組。
t["Object"] = Object;
t["Array"] = Array;
for (i in t)
{
if (obj instanceof t[i]) // 檢查 obj 的類。
{
s += "obj is an instance of " + i + "\n";
}
else
{
s += "obj is not an instance of " + i + "\n";
}
}
return(s); // 返回字符串。
}
var obj = new Date();
response.write(objTest(obj));
您可能感興趣的文章:
- 詳解JavaScript中typeof與instanceof用法
- Javascript typeof與instanceof的區(qū)別
- JavaScript類型檢測之typeof 和 instanceof 的缺陷與優(yōu)化
- 談?wù)勎覍avaScript中typeof和instanceof的深入理解
- 淺談javascript中的instanceof和typeof
- JavaScript中instanceof與typeof運算符的用法及區(qū)別詳細(xì)解析
- JS中typeof與instanceof之間的區(qū)別總結(jié)
- javascript之typeof、instanceof操作符使用探討
- 關(guān)于javascript中的typeof和instanceof介紹
- javascript instanceof,typeof的區(qū)別
- 菜鳥也能搞懂js中typeof與instanceof區(qū)別
相關(guān)文章
JavaScript中利用各種循環(huán)進(jìn)行遍歷的方式總結(jié)
這篇文章主要介紹了JavaScript中利用各種循環(huán)進(jìn)行遍歷的方式總結(jié),是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-11-11簡介JavaScript中Math.cos()余弦方法的使用
這篇文章主要介紹了簡介JavaScript中Math.cos()余弦方法的使用,是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-06-06深入理解JavaScript系列(17):面向?qū)ο缶幊讨耪撛敿?xì)介紹
這篇文章主要介紹了深入理解JavaScript系列(17):面向?qū)ο缶幊讨耪撛敿?xì)介紹,本文講解了概論、范式與思想、基于類特性和基于原型、基于靜態(tài)類、層次繼承等內(nèi)容,需要的朋友可以參考下2015-03-03javascript學(xué)習(xí)(一)構(gòu)建自己的JS庫
庫是一個飽受爭議的熱門話題。一種觀點認(rèn)為它是一種非常棒的工具,是任何開發(fā)者都不可或缺的;另一種觀點則認(rèn)為在不理解庫的內(nèi)部工作原理的情況下對庫形成依賴,會助長懶惰的風(fēng)氣從而導(dǎo)致開發(fā)者素質(zhì)下降2013-01-01javascript開發(fā)技術(shù)大全 第2章 開始JAVAScript之旅
1st JavaScript Editor ,除了有著色處,還有html標(biāo)簽、屬性、javascript事件、函數(shù),另外還可調(diào)用外部編輯來編輯網(wǎng)頁,也可將常用瀏覽器內(nèi)置在窗口中。2011-07-07JavaScript lastIndexOf方法入門實例(計算指定字符在字符串中最后一次出現(xiàn)的位置)
這篇文章主要介紹了JavaScript字符串對象的lastIndexOf方法入門實例,lastIndexOf方法用于計算指定字符在字符串中最后一次出現(xiàn)的位置,需要的朋友可以參考下2014-10-10