JS取出两个数组的不同或相同元素
JS合并两个数组的⽅法
我们在项⽬过程中,有时候会遇到需要将两个数组合并成为⼀个的情况。⽐如:
var a = [1,2,3];
var b = [4,5,6];
有两个数组a、b,需求是将两个数组合并成⼀个。⽅法如下:
1、concat
js的Array对象提供了⼀个叫concat()⽅法,连接两个或更多的数组,并返回结果。
var c = a.concat(b);//c=[1,2,3,4,5,6];
这⾥有⼀个问题,concat⽅法连接a、b两个数组后,a、b两个数组的数据不变,同时会返回⼀个新的数组。这样当我们需要进⾏多次的数组合并时,会造成很⼤的内存浪费,所以这个⽅法肯定不是最好的。
2、for循环
⼤概的思路是:遍历其中⼀个数组,把该数组中的所有元素依次添加到另外⼀个数组中。直接上代码:
for(var i in b){
a.push(b[i]);
}
这样的写法可以解决第⼀种⽅案中对内存的浪费,但是会有另⼀个问题:丑!这么说不是没有道理,如果能只⽤⼀⾏代码就搞定,岂不快哉~
3、apply
函数的apply⽅法有⼀个特性,那就是func.apply(obj,argv),argv是⼀个数组。所以我们可以利⽤这点,直接上代码:
a.push.apply(a,b);
调⽤a.push这个函数实例的apply⽅法,同时把,b当作参数传⼊,这样a.push这个⽅法就会遍历b数组的所有元素,达到合并的效果。
js数组方法总结
这⾥可能有点绕,我们可以把b看成[4,5,6],变成这样:
a.push.apply(a,[4,5,6]);
然后上⾯的操作就等同于:
a.push(4,5,6);
这样就很清楚了!
  另外,还要注意两个⼩问题:
  1)以上3种合并⽅法并没有考虑过a、b两个数组谁的长度更⼩。
  所以好的做法是预先判断a、b两个数组哪个更⼤,然后使⽤⼤数组合并⼩数组,这样就减少了数组元素操作的次数!
  2)有时候我们不希望原数组(a、b)改变,这时就只能使⽤concat了。
上⾯总结了下数组的常⽤⽅法,然后数组的去重也就简单易懂了;
1、取出两个数组的不同元素
1getArrDifference(arr1, arr2) {
2
at(arr2).filter(function(v, i, arr) {
4
5return arr.indexOf(v) === arr.lastIndexOf(v);
6
7    });
8
9 },
eg:ES6语法有更简洁⽅法可参考
2、取出两个数组的相同元素
1getArrEqual(arr1, arr2) {
2    let newArr = [];
3for (let i = 0; i < arr2.length; i++) { 4for (let j = 0; j < arr1.length; j++) { 5if(arr1[j] === arr2[i]){
6                newArr.push(arr1[j]);
7            }
8        }
9    }
10return newArr;
11 },

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。