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

js語法學(xué)習(xí)之判斷一個對象是否為數(shù)組

 更新時間:2014年05月13日 09:38:01   作者:  
這篇文章主要介紹了從javascript判斷一個對象是否為數(shù)組中學(xué)習(xí)js語法,需要的朋友可以參考下
1,真正的數(shù)組的判斷方法

javascript中最簡單的聲明數(shù)組方法為:
var a = [];
判斷是否為數(shù)組的最直接的方法為:
復(fù)制代碼 代碼如下:

a instanceof Array //true
a .constructor == Array //true

這里涉及到一個instanceof語法,instanceof是一個云算符,與"+-*/"一樣,它的語法如下:
result = obj intanceof class
是用來判斷一個對象是否是某個class的一個實例,運算結(jié)果返回true或者false。javascript中class的定義又是通過構(gòu)造函數(shù)進行初始化的,所以instanceof語法的右操作符class一定是Function的實例,即class instanceof Function一定為true,而且如果使用instanceof時右操作符不是Function,就會拋出TypeError異常。所有對象都是Object的實例,所以任何對象instanceof Object都返回true。雖然我們說對象都是通過構(gòu)造函數(shù)進行初始化的,但是instanceof卻不是通過檢查對象是否由該函數(shù)構(gòu)造的,而是通過是否由構(gòu)造函數(shù)的prototype繼承來的,下面這個例子可以說明這個問題:
復(fù)制代碼 代碼如下:

function Range(low, high) {
this.low = low;
this.high = high;
}
Range.prototype.constructor == Range; //true
Range.prototype = {
include: function(x){ return (x >= this.low && x <= this.high); },
exclude: function(x){ return (x < this.low && x > this.high); }
}
var r = new Range(0, 100);
r instanceof Range; //false
r instanceof Object; //true
Range.prototype.constructor == Objecct; //true

這里雖然r是通過new Range構(gòu)造的,但是r卻并不是Range的實例,這就是問題所在,Range.prototype賦值語句覆蓋了默認(rèn)的構(gòu)造函數(shù),沒對prototype賦值之前Range.prototype.constructor為Range,賦值之后變成了Object,這也好理解,因為
復(fù)制代碼 代碼如下:

Range.prototype = {
include: function(x){ return (x >= this.low && x <= this.high); },
exclude: function(x){ return (x < this.low && x > this.high); }
}

其實等價于:
復(fù)制代碼 代碼如下:

Range.prototype = new Object({
include: function(x){ return (x >= this.low && x <= this.high); },
exclude: function(x){ return (x < this.low && x > this.high); }
});

所以Range.prototype.constructor == Object,那么通過new Range創(chuàng)建出來的實例當(dāng)然就是Object的一個實例了。
看官方解釋更直接些:
The instanceof operator does not actually check whether r was initialized by the Range constructor. It checks whether it inherits from Range.prototype.
javascript中還有一個函數(shù)typeof具有與instanceof類似的功能,但是它返回的是具體的基本數(shù)據(jù)類型:number,string,function,object,undefined,boolean,只有這六種,不在這六種范圍內(nèi)的都返回object,也就是說typeof([])返回的是object,而不是array。
另一個涉及到的語法是constructor,constructor返回對象的構(gòu)造函數(shù):
復(fù)制代碼 代碼如下:

var a = [];
a.constructor; //Array

構(gòu)造函數(shù)是一個對象的初始化函數(shù),采用new調(diào)用,如果對象是一個Array,那么其constructor應(yīng)該就是Array,自己寫的類就不一定了,因為可能會吧prototype中的constructor更改掉。

2,偽數(shù)組的判斷方法

javascript中有一種偽數(shù)組,它可以使用類似于Array的遍歷方法進行遍歷,有l(wèi)ength屬性獲取元素的長度,可以使用[]下標(biāo)來獲取指定的元素,這種對象我們稱之為偽數(shù)組,JQuery中的對象就是典型的偽數(shù)組,如下圖:
 
所以判斷是否是偽數(shù)組的關(guān)鍵就是判斷是否有l(wèi)ength屬性,是否存在基本的數(shù)組操作函數(shù)splice,下面就是判斷方法:
復(fù)制代碼 代碼如下:

var is_array = function(value) {
return value &&
typeof value === 'object' &&
typeof value.length === 'number' &&
typeof value.splice === 'function' &&
!(value.propertyIsEnumerable('length'));
};

這里propertyIsEnumerable就是用來判斷l(xiāng)ength屬性是否可列舉,其實原生的String對象也是有類似Array的效果,但是我們不能把它當(dāng)作Array對象,所以這里需要判斷typeof value == "object",因為typeof一個String對象,返回的是string。

相關(guān)文章

  • 老生常談JavaScript面向?qū)ο蠡A(chǔ)與this指向問題

    老生常談JavaScript面向?qū)ο蠡A(chǔ)與this指向問題

    下面小編就為大家?guī)硪黄仙U凧avaScript面向?qū)ο蠡A(chǔ)與this指向問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • 一文徹底理解JavaScript原型與原型鏈

    一文徹底理解JavaScript原型與原型鏈

    這篇文章主要介紹了一文徹底理解JavaScript原型與原型鏈,JavaScript中有許多內(nèi)置對象,如:Object,?Math,?Date等,文章圍繞主題展開主題詳情,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • javascript使用smipleChart實現(xiàn)簡單圖表

    javascript使用smipleChart實現(xiàn)簡單圖表

    這篇文章主要介紹了javascript使用smipleChart實現(xiàn)簡單圖表的方法及示例分享,需要的朋友可以參考下
    2015-01-01
  • JavaScript讓瀏覽器停止加載頁面的方法

    JavaScript讓瀏覽器停止加載頁面的方法

    JavaScript中Window對象stop()方法用于停止頁面載入,該方法類似在瀏覽器上點擊停止載入按鈕,如果頁面在載入圖片或框架(iframe)時間過長,我門可以使用該方法來停止載入,可以應(yīng)用在判斷頁面載入時間,過長就不加載特效
    2023-09-09
  • 一些在TypeScript上費過時間的地方總結(jié)

    一些在TypeScript上費過時間的地方總結(jié)

    這篇文章主要給大家介紹了關(guān)于一些在ts上費過時間的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2021-11-11
  • 微信小程序?qū)崿F(xiàn)下拉加載更多商品

    微信小程序?qū)崿F(xiàn)下拉加載更多商品

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)下拉加載更多商品,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • layui導(dǎo)出所有數(shù)據(jù)的例子

    layui導(dǎo)出所有數(shù)據(jù)的例子

    今天小編就為大家分享一篇layui導(dǎo)出所有數(shù)據(jù)的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • JavaScript中的Web worker多線程API研究

    JavaScript中的Web worker多線程API研究

    這篇文章主要介紹了JavaScript中的Web worker多線程API研究,Web worker是HTML5的API,允許網(wǎng)頁在安全的情況下執(zhí)行多線程代碼,需要的朋友可以參考下
    2014-12-12
  • 通過javascript把圖片轉(zhuǎn)化為字符畫

    通過javascript把圖片轉(zhuǎn)化為字符畫

    平時我們都是使用軟件把圖片轉(zhuǎn)化為字符畫,今天我就用JAVASCRIPT把圖片轉(zhuǎn)化成字符畫,在娛樂中學(xué)習(xí)一些JS、HTML5、canvas的使用方法。
    2013-10-10
  • js實現(xiàn)單層數(shù)組轉(zhuǎn)多層樹

    js實現(xiàn)單層數(shù)組轉(zhuǎn)多層樹

    這篇文章主要介紹了js實現(xiàn)單層數(shù)組轉(zhuǎn)多層樹方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06

最新評論