【干货】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重写一次改方法的实现。这对我们很有帮助。


相关文章
|
4月前
|
JavaScript 前端开发 API
【JavaScript】<JS内建对象>JavaScript内建对象-Array对象
【1月更文挑战第17天】【JavaScript】<JS内建对象>JavaScript内建对象-Array对象
|
3天前
|
JavaScript 前端开发
JavaScript Array map() 方法
JavaScript Array map() 方法
|
22天前
|
JavaScript 算法 前端开发
JS算法必备之Array常用操作方法
这篇文章详细介绍了JavaScript中数组的创建、检测、转换、排序、操作方法以及迭代方法等,提供了数组操作的全面指南。
JS算法必备之Array常用操作方法
|
2月前
|
索引
|
2月前
|
前端开发
let array = [{id:‘001‘,name:‘小新‘,age:5},{ id:‘002‘,name:‘小葵‘]这样数据如何遍历,拿到其中一个值,数组中装对象如何获取其中一个固定的值
let array = [{id:‘001‘,name:‘小新‘,age:5},{ id:‘002‘,name:‘小葵‘]这样数据如何遍历,拿到其中一个值,数组中装对象如何获取其中一个固定的值
|
2月前
|
索引
ArrayList集合常用方法,.set可以用来生成图片和赋值命名,array.remove(1),array.set(1,“xxxx”)可以修改指定位置,array.size可以获取元素的个数
ArrayList集合常用方法,.set可以用来生成图片和赋值命名,array.remove(1),array.set(1,“xxxx”)可以修改指定位置,array.size可以获取元素的个数
|
4月前
|
前端开发 JavaScript
前端 js 经典:array 原生方法
前端 js 经典:array 原生方法
41 1
|
4月前
|
JavaScript 前端开发 索引
JavaScript array 原生 reduce 方法的模拟实现
JavaScript array 原生 reduce 方法的模拟实现
|
4月前
实现array.slice()方法
实现array.slice()方法
|
4月前
|
JavaScript 前端开发 索引
在JavaScript中,可以使用数组字面量或Array构造函数来创建一个数组对象
【4月更文挑战第16天】在JavaScript中,可以使用数组字面量或Array构造函数来创建一个数组对象
47 4