数组方法forEach slice splice去重

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--的原因是因为两个重复数相邻减掉 需要重新匹配计算
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值