ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

javascript – 获取第2,第3个阵列上没有的项目 – JS

2019-08-23 15:42:23  阅读:115  来源: 互联网

标签:javascript


我正在尝试创建一个函数,它将获取在第二个或第三个上无法看到的项目以及在函数内传递的即将到来的数组.

现在我的函数只获得类似的项目.我怎样才能使它得到差异(w / c是第二个和第三个以及前进阵列不存在的项目.

const callM = function(arrays) {
   arrays = Array.prototype.slice.call(arguments);


   let result = [];

  for(let i = 1; i < arrays.length; i++){
    for(let x = 0; x < arrays[i].length; x++){
      if(arrays[0].includes(arrays[i][x])){
        result.push(arrays[i][x]);
      }
    }
  }

  return result;

  };

console.log(callM([1, 2, 3, 4, 5], [5, 2, 10])); // -> must be [1, 3, 4]
console.log(callM([1, 2, 3, 4, 5], [5, 2, 10], [7, 1, 8])); // -> must be [3,4]

现在的逻辑有点偏,因为它恰恰相反.我该如何解决?

还有一种方法可以使用高阶函数(如reduce或filter)来完成此操作吗?

谢谢!

解决方法:

我会以不同的方式思考这个问题.作为两组之间的差异:数组0和数组1 … n

要获得数组0,只需将其从顶部移开即可

const arr0 = arrays.shift()

参考:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/shift

这将从数组中删除第一个数组
接下来我们合并剩下的数组

const arrN = arrays.reduce(function(prev, curr) {
  return prev.concat(curr)
})

参考:http://www.jstips.co/en/javascript/flattening-multidimensional-arrays-in-javascript/

不需要的,由@Phil提到的包括处理

下一个过滤器通过与自身进行比较从arrN复制

const unique = arrN.filter(function(elem, index, self) {
    return index == self.indexOf(elem);
})

参考:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter

下一个过滤器包括找到差异(或联合)

const diff = arr0.filter(function(item) {
    return !arrN.includes(item))
}

完整片段:

function callM(arrays) {

  const arr0 = arrays.shift()
  const arrN = arrays.reduce(function(prev, curr) {
    return prev.concat(curr)
  })
  //const unique = arrN.filter(function(elem, index, self) {
  //    return index == self.indexOf(elem)
  //})
  return arr0.filter(function(item) {
    return !arrN.includes(item)
  })
}

console.log(callM([[1, 2, 3, 4, 5], [5, 2, 10]]))
console.log(callM([[1, 2, 3, 4, 5], [5, 2, 10], [7, 1, 8]]))

当然ES6会更容易.

标签:javascript
来源: https://codeday.me/bug/20190823/1698379.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有