摘要:數(shù)組是一種類數(shù)組的對(duì)象,擁有對(duì)象的特性。檢測(cè)對(duì)象是否為數(shù)組眾所周知,不能正確檢測(cè)類型。值等于數(shù)組最大的整數(shù)屬性名加。長(zhǎng)度為,只包含一個(gè)元素的數(shù)組設(shè)小值將將會(huì)把屬性名大于等于的屬性刪除。下一篇介紹的方法。
Javascript,一門神奇的語(yǔ)言,它的數(shù)組也同樣獨(dú)特。我們要去其糟粕,取其精華,把常用的最優(yōu)實(shí)踐總結(jié)出來(lái)。如有錯(cuò)誤,請(qǐng)指出。
javascript數(shù)組是一種類數(shù)組的對(duì)象,擁有對(duì)象的特性。當(dāng)屬性名是小而連續(xù)的整數(shù)時(shí),應(yīng)該使用數(shù)組,否則,使用對(duì)象。
數(shù)組來(lái)源所有的數(shù)組都是Array構(gòu)造出來(lái)的,我們來(lái)測(cè)試一下constructor這個(gè)屬性。
var arr = []; arr.constructor === Array; // true arr.constructor === Array.prototype.constructor; // true創(chuàng)建數(shù)組
//數(shù)組字面量方式 var arr1 = [1, 2, 3]; // [1,2,3] //構(gòu)造函數(shù)方式 var arr2 = new Array(); // [] 空數(shù)組 var arr3 = new Array("9"); // ["9"] 一個(gè)字符串元素 var arr4 = new Array(9); // [] 數(shù)組長(zhǎng)度length為9 var arr5 = new Array([9]); // [[9]] 相當(dāng)于二維數(shù)組 var arr6 = new Array(1, 2, 3); // [1, 2, 3] var arr7 = new Array(1, function f(){}, {o : 6}, null,undefined,true); // 數(shù)組可以存儲(chǔ)任意混合數(shù)據(jù)類型
由于arr4的方式,當(dāng)只有一個(gè)數(shù)字參數(shù)傳遞到Array的構(gòu)造函數(shù)中,構(gòu)造函數(shù)會(huì)返回設(shè)置了length屬性的空數(shù)組。所以推薦使用數(shù)組字面量方式,短小而簡(jiǎn)潔。
檢測(cè)對(duì)象是否為數(shù)組var arr1 = [1, 2, 3]; typeof(arr1); // object
眾所周知,typeof不能正確檢測(cè)類型。
arr1 instanceof Array; //true
instanceof 方式在一個(gè)網(wǎng)頁(yè)內(nèi)是沒有問題,一旦嵌套其他網(wǎng)頁(yè),便存在兩個(gè)全局作用域,互相調(diào)用時(shí)的檢測(cè)就會(huì)出問題。
Array.isArray(arr1); // true
Array.isArray() 是ECMAScript5 新增的方法,沒有缺陷。唯一的問題是ie8瀏覽器不支持,ie9瀏覽器在嚴(yán)格模式下也不支持。
Object.prototype.toString.apply(arr1).slice(8, -1); // Array
最后一種方式是檢測(cè)類型的最好方法。
數(shù)組長(zhǎng)度數(shù)組的length也是它的屬性,增大length也不會(huì)發(fā)生越界錯(cuò)誤。
length值等于數(shù)組最大的整數(shù)屬性名加1。
var arr1 = []; arr1[9] = 1; // 長(zhǎng)度為10,只包含一個(gè)元素的數(shù)組
設(shè)小值將將會(huì)把屬性名大于等于length的屬性刪除。
如果將length值設(shè)為0,相當(dāng)于清空數(shù)組。
var arr2 = [1, 2, 3, 4, 5]; arr2.length = 3; // [1, 2, 3] arr2.length = 0; // []數(shù)組遍歷
遍歷數(shù)組不要使用for in循環(huán)遍歷數(shù)組,因?yàn)閒or in會(huì)遍歷原型鏈上的所有屬性,但我們并不需要這么多。推薦使用for循環(huán)的方式。
var arr1 = [1, 2, 3]; arr1.test = 9; //for in 方式 for(var prop in arr1){ cosole.log(prop, arr1[prop]); } // 輸出如下 // 0 1 // 1 2 // 2 3 // test 9 //for循環(huán)方式 for(var i = 0, len = arr1.length; i < len; i++){ console.log(arr1[i]); } //輸出如下 // 1 // 2 // 3
我們看到for in方式多出了一個(gè)test值,可以使用hasOwnProperty函數(shù)排除,但那會(huì)比f(wàn)or循環(huán)的方式慢很多。
緩存數(shù)組長(zhǎng)度很有必要的一步,每次訪問是有性能開銷的(最新的瀏覽器在這方面做了優(yōu)化)。
簡(jiǎn)單介紹了Array的相關(guān)基礎(chǔ)知識(shí),到這里也算是能對(duì)Array有更全面的理解了。下一篇介紹Array的方法。
Javascript雖然有很多不太容易弄懂的地方,隨著長(zhǎng)時(shí)間的學(xué)習(xí),我已經(jīng)慢慢地愛上它了(因?yàn)楝F(xiàn)在沒有妹子讓我愛)。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/78865.html
摘要:返回一個(gè)將數(shù)組所有元素用分隔符拼接成的字符串,默認(rèn)分隔符為逗號(hào)。重復(fù)的次數(shù)就是數(shù)組長(zhǎng)度減一,因?yàn)樽址欠指舴?。由于?shù)組本身是對(duì)象,擁有方法,利用它也能實(shí)現(xiàn)將數(shù)組拼接成一個(gè)字符串,只不過分隔符只能是逗號(hào)了。 接上一篇《愛上Javascript數(shù)組Array(一)——基礎(chǔ)介紹》,這一篇詳細(xì)介紹Array的所有方法。 所有數(shù)組的方法都定義在Array.prototype上,而Array.p...
摘要:通過構(gòu)造函數(shù)得到的實(shí)例對(duì)象內(nèi)部會(huì)包含一個(gè)指向構(gòu)造函數(shù)的對(duì)象的指針。 JavaScript 高級(jí) 學(xué)習(xí)目標(biāo): 理解面向?qū)ο箝_發(fā)思想 掌握 JavaScript 面向?qū)ο箝_發(fā)相關(guān)模式 掌握在 JavaScript 中使用正則表達(dá)式 面向?qū)ο蠼榻B 程序中面向?qū)ο蟮幕倔w現(xiàn) 在 JavaScript 中,所有數(shù)據(jù)類型都可以視為對(duì)象,當(dāng)然也可以自定義對(duì)象。自定義的對(duì)象數(shù)據(jù)類型就是面向?qū)ο笾?..
摘要:通過構(gòu)造函數(shù)得到的實(shí)例對(duì)象內(nèi)部會(huì)包含一個(gè)指向構(gòu)造函數(shù)的對(duì)象的指針。 JavaScript 高級(jí) 學(xué)習(xí)目標(biāo): 理解面向?qū)ο箝_發(fā)思想 掌握 JavaScript 面向?qū)ο箝_發(fā)相關(guān)模式 掌握在 JavaScript 中使用正則表達(dá)式 面向?qū)ο蠼榻B 程序中面向?qū)ο蟮幕倔w現(xiàn) 在 JavaScript 中,所有數(shù)據(jù)類型都可以視為對(duì)象,當(dāng)然也可以自定義對(duì)象。自定義的對(duì)象數(shù)據(jù)類型就是面向?qū)ο笾?..
閱讀 2410·2021-11-12 10:34
閱讀 1479·2019-08-29 16:15
閱讀 2691·2019-08-29 15:17
閱讀 1352·2019-08-23 17:09
閱讀 396·2019-08-23 11:37
閱讀 2457·2019-08-23 10:39
閱讀 476·2019-08-22 16:43
閱讀 3119·2019-08-22 14:53