数组相关操作笔记

最近在FFC上做题,做到了算法中的数组相关操作,所以也简单做下笔记,以备不时之需~

创建数组

1.使用关键词new来创建数组对象

1
var arr=new Array('a','b','c');

2.直接创建(简单粗暴)

1
var arr=['a','b','c'];

数组的相关操作方法

1.map方法可以方便的迭代数组

map方法会迭代数组中的每一个元素,并根据回调函数来处理每一个元素,最后返回一个新数组。注意,这个方法不会改变原始数组。

1
2
3
var timesFour = arr.map(function(val){
return val * 4;
});

在我们的例子中,回调函数只有一个参数,即数组中元素的值 (val 参数)但其实,你的回调函数也可以支持多个参数,譬如:元素的索引index、原始数组arr。

2.reduce用来迭代一个数组,并且把它累积到一个值中

使用 reduce 方法时,你要传入一个回调函数,这个回调函数的参数是一个累加器(比如例子中的 previousVal)和当前值 (currentVal)。
reduce 方法有一个可选的第二参数,它可以被用来设置累加器的初始值。如果没有在这定义初始值,那么初始值将变成数组中的第一项,而 currentVal 将从数组的第二项开始。

下面的例子使用了 reduce 来让数组中的所有值相减:

1
2
3
var singleVal = array.reduce(function(previousVal, currentVal) {
return previousVal - currentVal;
}, 0);

3.filter方法用来迭代一个数组,并且按给出的条件过滤出符合的元素

filter 方法传入一个回调函数,这个回调函数会携带一个参数,参数为当前迭代的项(我们叫它 val )。
回调函数返回 true 的项会保留在数组中,返回 false 的项会被过滤出数组。

下面的代码示例展示了使用 filter 来移除数组中值等于5的项:
(注意: 我们忽略了第二参数和第三参数,因为例子中我们只需要第一参数就够了。)

1
2
3
array = array.filter(function(val) {
return val !== 5;
});

4.使用sort方法,你可以很容易的按字母顺序或数字顺序对数组中的元素进行排序

与我们之前用的数组方法仅仅返回一个新数组不同, sort 方法将改变原数组,返回被排序后的数组。
sort 可以把比较函数作为参数传入。比较函数有返回值,当 a 小于 b,返回一个负数;当 a 大于 b ,返回一个正数;相等时返回0。
如果没有传入比较函数,它将把值全部转成字符串,并按照字母顺序进行排序。

下面的例子将展示 sort 的使用,传入的比较函数把元素按照从小到大的顺序进行排列:

1
2
3
4
var array = [1, 12, 21, 2];
array.sort(function(a, b) {
return a - b;
});

5.使用 reverse 方法来翻转数组(也就是倒序)

1
2
var myArray = [1, 2, 3];
myArray.reverse(); //myArray = [3, 2, 1];

6.concat方法可以把两个数组的内容合并到一个数组中

concat 方法的参数应该是一个数组。参数中的数组会拼接在原数组的后面,并作为一个新数组返回。

下面是一个拼接数组的例子,用concat 把 otherArray 拼接在 oldArray 的后面:

1
newArray = oldArray.concat(otherArray);

7.split方法按指定分隔符将字符串分割为数组(可以用于将字符串转为数组)

你要给 split 方法传递一个参数,这个参数将会作为一个分隔符。

下面的例子展示了 split 方法的使用,按照 s 字母进行分割:

1
var array = string.split('s');

8.用join方法来把数组转换成字符串

下面展示了使用 join 来将数组中的每一项放入字符串,并用 and 进行连接:

1
2
3
var veggies = ["Celery", "Radish", "Carrot", "Potato"];
var salad = veggies.join(" and ");
console.log(salad); // "Celery and Radish

9.slice返回数组的一部分(提取字符串的一部分)

1
2
3
var arr=['a','b','c','d'];
arr.slice(1,2) //['b','c']接收一或两个参数,分别为要截取的新数组的开始位置和结束位置,(新数组不包含结束位置项)
arr.slice(2); //['c','d']如果只有一个参数,则表示从截取该位置的项到末尾的项

10.splice在数组中插入或删除一些元素,返回一个包含被删除项目的数组

1
2
3
4
var arr=['a','b','c','d'];
arr.splice(1,2); //会返回删除的项组成的数组,原数组变成['a','d'],如果是两个参数,则分别表示要删除的第一项的位置和要删除的项数。这是一个很强大的方法,一般用于在中部插入项,也可以用于删除和替换。
arr.splice(2,0,'e','f'); //原数组变成["a","b","e","f,"c","d"],如果提供3个以上的参数,则第一个表示插入的起始位置,第二个表示要删除的项,第三个以后表示要插入的项
arr.splice(1,1,'e','f'); //替换用法,原数组变成["a","e","f","c","d"]

11.indexOf返回参数出现的第一处索引值

1
2
3
var arr=['a','b','c','d'];
arr.indexOf('b'); //1(从零开始)
arr.lastindexOf('c'); //2,最后出现的位置

如果找不到则会返回-1;可以接受第二个参数,表示从第几个位置开始查找

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

1
2
3
4
5
6
7
var a=[1,2,3,4,3,2,1];
a.every(function(item,index,arr){
return (item>2)
}); //false

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

1
2
3
4
5
6
7
var a=[1,2,3,4,3,2,1];
a.some(function(item,index,arr){
return (item>2)
}); //true

参考文章:

JavaScript Array(数组)对象
Array对象的方法大全,看看你知道多少.