欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript instanceof,typeof的區(qū)別

 更新時(shí)間:2010年03月24日 19:02:46   作者:  
區(qū)分string 與 String的區(qū)別
為什么結(jié)果會(huì)是false呢?
復(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)算符
返回一個(gè) Boolean 值,指出對(duì)象是否是特定類的一個(gè)實(shí)例。
result = object instanceof class
參數(shù)
result
必選項(xiàng)。任意變量。
object
必選項(xiàng)。任意對(duì)象表達(dá)式。
class
必選項(xiàng)。任意已定義的對(duì)象類。
說(shuō)明
如果 object 是 class 的一個(gè)實(shí)例,則 instanceof 運(yùn)算符返回 true。如果 object 不是指定類的一個(gè)實(shí)例,或者 object 是 null,則返回 false。
示例
下面的例子舉例說(shuō)明了 instanceof 運(yùn)算符的用法。
復(fù)制代碼 代碼如下:

function objTest(obj){
var i, t, s = ""; // 創(chuàng)建變量。
t = new Array(); // 創(chuàng)建一個(gè)數(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都能用來(lái)判斷一個(gè)變量是否為空或是什么類型的變量。
typeof用以獲取一個(gè)變量的類型,typeof一般只能返回如下幾個(gè)結(jié)果:number,boolean,string,function,object,undefined。我們可以使用typeof來(lái)獲取一個(gè)變量是否存在,如if(typeof a!="undefined"){},而不要去使用if(a)因?yàn)槿绻鸻不存在(未聲明)則會(huì)出錯(cuò),對(duì)于Array,Null等特殊對(duì)象使用typeof 一律返回object,這正是typeof的局限性。
如果我們希望獲取一個(gè)對(duì)象是否是數(shù)組,或判斷某個(gè)變量是否是某個(gè)對(duì)象的實(shí)例則要選擇使用instanceof。instanceof用于判斷一個(gè)變量是否某個(gè)對(duì)象的實(shí)例,如var a=new Array();alert(a instanceof Array);會(huì)返回true,同時(shí)alert(a instanceof Object)也會(huì)返回true;這是因?yàn)锳rray是object的子類。再如:function test(){};var a=new test();alert(a instanceof test)會(huì)返回true。
談到instanceof我們要多插入一個(gè)問(wèn)題,就是function的arguments,我們大家也許都認(rèn)為arguments是一個(gè)Array,但如果使用instaceof去測(cè)試會(huì)發(fā)現(xiàn)arguments不是一個(gè)Array對(duì)象,盡管看起來(lái)很像。
另外:
測(cè)試 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測(cè)試的object是指js語(yǔ)法中的object,不是指dom模型對(duì)象。
使用typeof會(huì)有些區(qū)別
alert(typeof(window) 會(huì)得 object
年輕的時(shí)候,先少?gòu)U話,多做事。

相關(guān)文章

  • javascript中的some方法使用解讀

    javascript中的some方法使用解讀

    這篇文章主要介紹了javascript中的some方法使用解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 如何在項(xiàng)目中使用log4.js的方法步驟

    如何在項(xiàng)目中使用log4.js的方法步驟

    這篇文章主要介紹了如何在項(xiàng)目中使用log4.js的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • JavaScript獲取網(wǎng)頁(yè)表單提交方式的方法

    JavaScript獲取網(wǎng)頁(yè)表單提交方式的方法

    這篇文章主要介紹了JavaScript獲取網(wǎng)頁(yè)表單提交方式的方法,可判斷表單提交方式是get還是post,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-04-04
  • 微信小程序返回上一頁(yè)的各種方法實(shí)例

    微信小程序返回上一頁(yè)的各種方法實(shí)例

    在開(kāi)發(fā)小程序的時(shí)候我們總是能遇到各種奇怪的需求,下面這篇文章主要給大家介紹了關(guān)于微信小程序返回上一頁(yè)的各種方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • Javascript訪問(wèn)html頁(yè)面的控件的方法詳細(xì)分析

    Javascript訪問(wèn)html頁(yè)面的控件的方法詳細(xì)分析

    這段時(shí)間在公司比較的空閑,決定研究研究javascript訪問(wèn)html控件,這是很普遍的,這里我系統(tǒng)的研究javascript的訪問(wèn)方式,測(cè)試通過(guò)并有下面一些研究成就,供大家分享和補(bǔ)充。
    2008-08-08
  • JavaScript實(shí)現(xiàn)動(dòng)態(tài)表單生成

    JavaScript實(shí)現(xiàn)動(dòng)態(tài)表單生成

    這篇文章主要來(lái)和大家一起深入探討如何使用JavaScript實(shí)現(xiàn)一個(gè)動(dòng)態(tài)表單生成器,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考一下
    2024-01-01
  • JavaScript雙問(wèn)號(hào)(??)操作符用法詳解

    JavaScript雙問(wèn)號(hào)(??)操作符用法詳解

    在現(xiàn)代JavaScript開(kāi)發(fā)中,處理變量默認(rèn)值是一個(gè)常見(jiàn)但容易引發(fā)bug的操作,很多開(kāi)發(fā)者可能都遇到過(guò)這樣的問(wèn)題:使用||設(shè)置默認(rèn)值時(shí),意外覆蓋了0、''等合法值,這時(shí)候,ES2020引入的雙問(wèn)號(hào)操作符(??)就能完美解決這類問(wèn)題,本文將帶您全面掌握這個(gè)操作符的使用場(chǎng)景和高級(jí)技巧
    2025-04-04
  • 利用jsonp跨域調(diào)用百度js實(shí)現(xiàn)搜索框智能提示

    利用jsonp跨域調(diào)用百度js實(shí)現(xiàn)搜索框智能提示

    這篇文章主要為大家詳細(xì)介紹了使用jsonp跨域調(diào)用百度js實(shí)現(xiàn)搜索框智能提示,感興趣的小伙伴們可以參考一下
    2016-08-08
  • JS當(dāng)前頁(yè)面登錄注冊(cè)框,固定DIV,底層陰影的實(shí)例代碼

    JS當(dāng)前頁(yè)面登錄注冊(cè)框,固定DIV,底層陰影的實(shí)例代碼

    下面小編就為大家?guī)?lái)一篇JS當(dāng)前頁(yè)面登錄注冊(cè)框,固定DIV,底層陰影的實(shí)例代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-09-09
  • canvas實(shí)現(xiàn)十二星座星空?qǐng)D

    canvas實(shí)現(xiàn)十二星座星空?qǐng)D

    本文主要分享了canvas實(shí)現(xiàn)十二星座星空?qǐng)D的示例代碼。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02

最新評(píng)論