forEach()方法需要一个函数作为参数
像这种函数,由我们创建但是不由我们调用的,我们称为回调函数
数组中有几个元素就会执行几次,每次执行时,浏览器将会遍历到元素
以实参的形式传递进来,我们可以定义形参,来读取这些内容
浏览器会在回调函数中传递三个参数
第一个参数,就是当前正在遍历的元素
第二个参数,就是当前正在遍历的元素的索引
第三个参数,就是正在遍历的数组
var arr = ['孙悟空','猪八戒','沙和尚','唐僧','白骨精'];
arr.forEach(function(value,index,obj) {
console.log(index + '=' + value) // 0=孙悟空 1=猪八戒 2=沙和尚
3=唐僧 4=白骨精
console.log(obj == arr) //true
})
slice()
可以用来从数组提取指定元素
该方法不会改变元素数组 而是将截取到的元素封装到一个新数组中返回
参数:1.截取开始的位置索引,包含开始索引
2.截取结束位置的索引,不包含结束索引 -第二个参数可以省略不写,此时会截取从开始索引往后的所有元素
- 索引可以传递一个负值,如果传递一个负值,则从后往前计算
-1 倒数第一个 - 2 倒数第二个
var result = arr.slice(1,4);
result = arr.slice(3);
console.warn(result);
splice()
- 可以用于删除数组中的指定元素
- 使用splice()会影响到原数组,会将指定元素从原始数组中删除
并将删除的元素作为返回值返回
参数:
第一个 表示开始位置的索引
第二个 表示删除的数量
第三个及以后 可以传递一些新的元素 这些元素将会自动插入到开始位置索引前边
var newArr = arr.splice(0,2);
console.warn(newArr)
var arr = [1,2,3,2,2,1,3,4,2,5];
var newArr = []
for (var i=0;i<arr.length;i++) {
for(var j = i+1;j<arr.length;j++) {
if(arr[i] == arr[j]) {
arr.splice(j,1)
j--;
}
}
}
console.warn(arr)
j--的原因是因为两个重复数相邻减掉 需要重新匹配计算