【干货】Array对象的方法大全,看看你知道多少.

从《高级程序设计》中整理出来的数组的概念和数组对象的一些方法,分享给大家同时也是复习复习,有不正确的地方欢迎指正,共同进步。


一.认识引用类型

js中的数据类型分为基本类型(string,boolean,undefined,null,number)和引用类型。引用类型的值(对象)是引用类型的一个实例,在ECMA中,引用类型是一种数据结构,它相当于其他语言中的类。而对象则是某个特定类型的实例

二.认识数组

Array是引用类型中的一种,也是js中很常用面试题也经常出现的类型。

创建数组的方式有两种:

1.使用用Array构造函数:

var arr = new Array('1','2','3');

2.使用字面量:

var arr = ['1','2','3'];

3.如何检测检测数:

var arr = ['1','2','3'];

if(arr instanceof Array){

//do something

};

三.数组方法

1.转换方法:

var a=['1','2','3'];

a.toString();  //"1,2,3",此方法会返回会返回每一项值的字符串以逗号拼接成一个字符串

a.valueOf();  //['1','2','3'],返回的还是数组

a.toLocaleString();  //"1,2,3",通常和toString()方法的结果一样

2.栈和队列方法

var a=['1','2','3','4'];

a.push('5'); //5,此方法会返回末尾新增一项后数组的长度,原数组变成['1','2','3','4','5']

a.pop(); //'4',此方法会返回删除的末尾一项,原数组变成['1','2','3']

a.shift(); //'1',此方法会返回删除的头部一项,原数组变成['2','3','4']

a.unshift('0'); //5,此方法会返回头部新增一项后数组的长度,原数组变成['0','1','2','3','4']

3.重排序方法

var a=[3,1,9,18];

a.reverse(); //[18,9,1,3],倒叙输出

a.sort(); //[1,18,3,9],字符串升序排序方法,会将每一项转换成字符串后在进行排序,'18'排在‘3’前面

a.sort( function(value1,value2){

return value1-value2

} ); //[1,3,9,18],此方法还可以接受一个比较函数,此函数接收两个参数,如果第一个参数应该位于第二个参数之前则返回一个负数,如果反过来则返回正数,相等则返回0

4.操作方法

var a=['0','1','2','3'];

a.concat(['4',5]); //['0','1','2','3','4','5'],原数组不变,返回一个合并后的数组

a.concat('4','5'); //该方法还可以接收字符串添加到末尾,结果和上面一样

a.slice(1,2); //['1','2'],接收一或两个参数,分别为要截取的新数组的开始位置和结束位置,(新数组不包含结束位置项)

a.slice(2); //['3','4']如果只有一个参数,则表示从截取该位置的项到末尾的项

a.splice(1,2); //会返回删除的项组成的数组,原数组变成['0','3'],如果是两个参数,则分别表示要删除的第一项的位置和要删除的项数。这是一个很强大的方法,一般用于在中部插入项,也可以用于删除和替换。

a.splice(2,0,'1.1','1.2'); //原数组变成["0","1","1.1","1.2","2","3"],如果提供3个以上的参数,则第一个表示插入的起始位置,第二个表示要删除的项,第三个以后表示要插入的项

a.splice(1,1,'1.1','1.2'); //替换用法,原数组变成["0","1.1","1.2","2","3"]

5.位置方法

var a=['0','1','2','3','2','1','0'];

a.indexOf('2'); //2,返回此项在数组中的第一个位置(从0开始,左边算起)

a.lastIndexOf('2'); //4,返回此项在数组中的最后一个位置(从0开始,左边算起)

a.index0f('5'); //找不到则返回-1

a.indexOf('2',3); //4,可接收第二个参数,表示开始查找的位置

这两个方法的兼容性:IE9+

6.迭代方法

ECMAScript5为数组定义了5个迭代方法,接收两个参数:要在每一项运行的函数和上下文(第二个参数可省略);

传入的函数接收三个参数(数组项的值,该项在数组中的位置,和数组对象本身)。这5个想法分别是:

every() //对数组中的每一项运行传入的函数,如果每一项都返回true,则返回true

filter() //对数组中的每一项运行传入的函数,返回一个由会返回true的项组成的数组

forEach() //对数组中的每一项运行传入的函数。没有返回值。作用相当于for

map() //对数组中的每一项运行传入的函数,返回一个由每项调用传入函数的结果组成的数组

some() //对数组中的每一项运行传入的函数,如果该函数对某一项返回true,则返回true

这些方法的介绍都不太好理解,以下是一些例子:

var a=[1,2,3,4,3,2,1];

a.every(function(item,index,arr){

return (item>2)

}); //false

a.every(function(item,index,arr){

return (item>0)

}); //true

a.some(function(item,index,arr){

return (item>2)

}); //true

a.filter(function(item,index,arr){

return (item>2)

}); //[3, 4, 3]

a.map(function(item,index,arr){

return (item>2)

}); //[false, false, true, true, true, false, false]

a.map(function(item,index,arr){

return (item*2)

}); //[[2, 4, 6, 8, 6, 4, 2]

var b=[];

a.forEach(function(item,index,arr){

b[index]=item*2

});

console.log(b); //[[2, 4, 6, 8, 6, 4, 2]

这些方法的兼容性IE9+

7.归并方法

两个归并方法:reduce()和reduceRight();这两个方法接收一个用于迭代的函数(reduce()从头部开始迭代,reduceRight()从尾部开始)。

这个函数接收四个参数:当前项的前一项,当前迭代到的项,当前项的位置,数组对象。

var a=[1,2,3,4,5];

a.reduce(function(pre,cur,index,arr){

return pre+cur;

}); //15

var a=["1","2","3","4","5"];

a.reduceRight(function(pre,cur,index,arr){

return pre+cur;

}); //"54321"

a.reduce(function(pre,cur,index,arr){

return pre+cur;

}); //"12345"

这些方法的兼容性IE9+


小结:

数组往往考察算法和对一门语言理解的重要切入点。在用的过程最好也能想想这些方法的实现,或者通过Array.prototype重写一次改方法的实现。这对我们很有帮助。

码了那么多。如果觉得不错记得给个赞。欢迎指指正,欢迎带原文链接转载。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容