javascript instanceof,typeof的區(qū)別
更新時間:2010年03月24日 19:02:46 作者:
區(qū)分string 與 String的區(qū)別
為什么結(jié)果會是false呢?
<script type="text/javascript">
var aColors = ["red", "green", "blue"];
alert(typeof aColors[0]); //output "string"
alert(aColors[0] instanceof String); //output "false";
</script>
你要區(qū)分string 與 String的區(qū)別
aColors[0] 是 string值類型, 當(dāng)然不是String的實(shí)例啦。參考下面代碼
var aColors = ["red", "green", "blue"];
aColors[0]= new String("1")
alert(typeof aColors[0]); //output "Object"
alert(aColors[0] instanceof String); //output "true";
更多可以參考下面的文章:
instanceof 運(yùn)算符
返回一個 Boolean 值,指出對象是否是特定類的一個實(shí)例。
result = object instanceof class
參數(shù)
result
必選項(xiàng)。任意變量。
object
必選項(xiàng)。任意對象表達(dá)式。
class
必選項(xiàng)。任意已定義的對象類。
說明
如果 object 是 class 的一個實(shí)例,則 instanceof 運(yùn)算符返回 true。如果 object 不是指定類的一個實(shí)例,或者 object 是 null,則返回 false。
示例
下面的例子舉例說明了 instanceof 運(yùn)算符的用法。
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();
document.write(objTest(obj));
instanceof和typeof都能用來判斷一個變量是否為空或是什么類型的變量。
typeof用以獲取一個變量的類型,typeof一般只能返回如下幾個結(jié)果:number,boolean,string,function,object,undefined。我們可以使用typeof來獲取一個變量是否存在,如if(typeof a!="undefined"){},而不要去使用if(a)因?yàn)槿绻鸻不存在(未聲明)則會出錯,對于Array,Null等特殊對象使用typeof 一律返回object,這正是typeof的局限性。
如果我們希望獲取一個對象是否是數(shù)組,或判斷某個變量是否是某個對象的實(shí)例則要選擇使用instanceof。instanceof用于判斷一個變量是否某個對象的實(shí)例,如var a=new Array();alert(a instanceof Array);會返回true,同時alert(a instanceof Object)也會返回true;這是因?yàn)锳rray是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對象,盡管看起來很像。
另外:
測試 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
年輕的時候,先少廢話,多做事。
復(fù)制代碼 代碼如下:
<script type="text/javascript">
var aColors = ["red", "green", "blue"];
alert(typeof aColors[0]); //output "string"
alert(aColors[0] instanceof String); //output "false";
</script>
你要區(qū)分string 與 String的區(qū)別
aColors[0] 是 string值類型, 當(dāng)然不是String的實(shí)例啦。參考下面代碼
var aColors = ["red", "green", "blue"];
aColors[0]= new String("1")
alert(typeof aColors[0]); //output "Object"
alert(aColors[0] instanceof String); //output "true";
更多可以參考下面的文章:
instanceof 運(yùn)算符
返回一個 Boolean 值,指出對象是否是特定類的一個實(shí)例。
result = object instanceof class
參數(shù)
result
必選項(xiàng)。任意變量。
object
必選項(xiàng)。任意對象表達(dá)式。
class
必選項(xiàng)。任意已定義的對象類。
說明
如果 object 是 class 的一個實(shí)例,則 instanceof 運(yùn)算符返回 true。如果 object 不是指定類的一個實(shí)例,或者 object 是 null,則返回 false。
示例
下面的例子舉例說明了 instanceof 運(yùn)算符的用法。
復(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();
document.write(objTest(obj));
instanceof和typeof都能用來判斷一個變量是否為空或是什么類型的變量。
typeof用以獲取一個變量的類型,typeof一般只能返回如下幾個結(jié)果:number,boolean,string,function,object,undefined。我們可以使用typeof來獲取一個變量是否存在,如if(typeof a!="undefined"){},而不要去使用if(a)因?yàn)槿绻鸻不存在(未聲明)則會出錯,對于Array,Null等特殊對象使用typeof 一律返回object,這正是typeof的局限性。
如果我們希望獲取一個對象是否是數(shù)組,或判斷某個變量是否是某個對象的實(shí)例則要選擇使用instanceof。instanceof用于判斷一個變量是否某個對象的實(shí)例,如var a=new Array();alert(a instanceof Array);會返回true,同時alert(a instanceof Object)也會返回true;這是因?yàn)锳rray是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對象,盡管看起來很像。
另外:
測試 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
年輕的時候,先少廢話,多做事。
您可能感興趣的文章:
- JS中typeof與instanceof之間的區(qū)別總結(jié)
- 詳解JavaScript中typeof與instanceof用法
- javascript instanceof 與typeof使用說明
- 關(guān)于javascript中的typeof和instanceof介紹
- javascript之typeof、instanceof操作符使用探討
- 談?wù)勎覍avaScript中typeof和instanceof的深入理解
- 菜鳥也能搞懂js中typeof與instanceof區(qū)別
- Javascript typeof與instanceof的區(qū)別
- 淺談javascript中的instanceof和typeof
- 如何判別JS中的數(shù)據(jù)類型?一篇文章教你徹底弄懂typeof和instanceof
相關(guān)文章
Javascript訪問html頁面的控件的方法詳細(xì)分析
這段時間在公司比較的空閑,決定研究研究javascript訪問html控件,這是很普遍的,這里我系統(tǒng)的研究javascript的訪問方式,測試通過并有下面一些研究成就,供大家分享和補(bǔ)充。2008-08-08
JavaScript實(shí)現(xiàn)動態(tài)表單生成
這篇文章主要來和大家一起深入探討如何使用JavaScript實(shí)現(xiàn)一個動態(tài)表單生成器,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考一下2024-01-01
利用jsonp跨域調(diào)用百度js實(shí)現(xiàn)搜索框智能提示
這篇文章主要為大家詳細(xì)介紹了使用jsonp跨域調(diào)用百度js實(shí)現(xiàn)搜索框智能提示,感興趣的小伙伴們可以參考一下2016-08-08
JS當(dāng)前頁面登錄注冊框,固定DIV,底層陰影的實(shí)例代碼
下面小編就為大家?guī)硪黄狫S當(dāng)前頁面登錄注冊框,固定DIV,底層陰影的實(shí)例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09

