15-数组的四个基本方法&数组的遍历
前言
数组的四个基本方法如下:
方法 | 描述 | 备注 |
---|---|---|
push() | 向数组的最后面插入一个或多个元素,返回结果为该数组新的长度 | 会改变原数组 |
pop() | 删除数组中的最后一个元素,返回结果为被删除的元素 | 会改变原数组 |
unshift() | 在数组最前面插入一个或多个元素,返回结果为该数组新的长度 | 会改变原数组 |
shift() | 删除数组中的第一个元素,返回结果为被删除的元素 | 会改变原数组 |
遍历数组的方法如下:
数组的四个基本方法(数组元素的添加和删除)
push()
push()
:向数组的最后面插入一个或多个元素,返回结果为该数组新的长度。
语法:
1 | 数组的新长度 = 数组.push(元素); |
代码举例:
1 | var arr = ["王一", "王二", "王三"]; |
pop()
pop()
:删除数组中的最后一个元素,返回结果为被删除的元素。
语法:
1 | 被删除的元素 = 数组.pop(); |
代码举例:
1 | var arr = ["王一", "王二", "王三"]; |
unshift()
unshift()
:在数组最前面插入一个或多个元素,返回结果为该数组新的长度。插入元素后,其他元素的索引会依次调整。
语法:
1 | 数组的新长度 = 数组.unshift(元素); |
代码举例:
1 | var arr = ["王一", "王二", "王三"]; |
shift()
shift()
:删除数组中的第一个元素,返回结果为被删除的元素。
语法:
1 | 被删除的元素 = 数组.shift(); |
代码举例:
1 | var arr = ["王一", "王二", "王三"]; |
数组的遍历
遍历数组即:获取并操作数组中的每一个元素。
数组迭代方法包括:every()、filter()、forEach()、map()、some()
PS:这几个方法不会修改原数组。
语法格式:
1 | 数组/boolean/无 = 数组.every/filter/forEach/map/some( |
有了这几种方法,就可以替代一些for循环了。下面依次来介绍。
for循环 遍历
举例:
1 | var arr = ["生命壹号","许嵩","永不止步"]; |
打印结果:
forEach() 遍历
forEach()
这种遍历方法只支持IE8以上的浏览器。IE8及以下的浏览器均不支持该方法。所以如果需要兼容IE8,则不要使用forEach,改为使用for循环来遍历即可。
forEach()方法需要一个函数作为参数。这种函数,是由我们创建但是不由我们调用的,我们称为回调函数。
数组中有几个元素,该回调函数就会执行几次。执行完毕后,浏览器会将遍历到的元素。
回调函数中传递三个参数:
-
第一个参数,就是当前正在遍历的元素
-
第二个参数,就是当前正在遍历的元素的索引
-
第三个参数,就是正在遍历的数组
代码举例:
1 | var arr = ["王一", "王二", "王三"]; |
打印结果:
1 | item:王一 |
map()方法
解释:对数组中每一项运行回调函数,返回该函数的结果,组成的新数组(返回的是加工之后的新数组)。
比如说,有一个已知的数组arr1,我要求让arr1中的每个素加10,这里就可以用到map方法。举例:
1 | var arr1 = [1, 3, 6, 2, 5, 6]; |
打印结果:
举例2:
1 | var arr1 = ["千古", "宿敌", "南山忆", "素颜"]; |
结果:
filter
语法:
1 | Array.prototype.filter(function(item, index){}) |
解释:对数组中每一项运行回调函数,该函数返回结果是true的项,将组成新的数组(返回值就是这个新的数组)。
举例1:找出数组 arr1 中大于4的元素,返回一个新的数组。代码如下:
1 | var arr1 = [1, 3, 6, 2, 5, 6]; |
打印结果:
举例2:
1 | var arr1 = ["千古", "宿敌", "南山忆", "素颜"]; |
结果:
every()方法
解释:对数组中每一项运行回调函数,如果都返回true,every就返回true;如果有一项返回false,则停止遍历,此方法返回false。
注意:every()方法的返回值是boolean值,参数是回调函数。
举例:
1 | var arr1 = ["千古", "宿敌", "南山忆", "素颜"]; |
some()方法
解释:对数组中每一项运行回调函数,只要有一项返回true,则停止遍历,此方法返回true。