微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如果对象的属性包含任何子字符串,则从数组中减少对象

如何解决如果对象的属性包含任何子字符串,则从数组中减少对象

我试图减少数组内的所有对象,它们的属性标题”包含单独的 JSON 文件中包含的任何子字符串。我一直在尝试按对象属性过滤数组,但它实际上不起作用,并且 reduce() 方法可以更好地实现它。

目标是对未排除的对象进行一些数学运算,例如: 如果任何对象的属性 Title 与所包含的属性不同(qa、质量保证、软件测试员),那么我们应该将其删除并且不要将其计算在内

我正在尝试使用 noobie 的方式来实现它,但无法实现它,我认为更好的方法是通过减少不应计算的对象来转换 positionArray,然后进行数学运算。

我的功能

calculateSoftwareExperience: async function () {
      filetoCurate.forEach(candidate => {
        const positionsArray = candidate.softwareIndustryPositions;
        console.log(positionsArray)
        //const reducedArray = positionsArray.reduce(x => x.title)
        
        //console.log(positionsArray)
        if (Array.isArray(positionsArray) && positionsArray.length) {
          // array exists and is not empty
          positionsArray.forEach(position => {
            let title = position.title;
            
            if (titlesIncluded.some(x => title.includes(x))) {
              console.log(title)
              const firstFrom = positionsArray[positionsArray.length - 1].from;
              const lastTo = positionsArray[0].to;
              let diff = lastTo - firstFrom;
              let days = (diff * 1000) / (60 * 60 * 24 * 1000) / 1000;
              let months = Math.floor(days / 31);
              //console.log(firstFrom,"to",lastTo,"diff = ",months);
              candidate.softwareIndustryExp = months;
              //console.log(months)
            }
          });
        } else {
          candidate.softwareIndustryExp = 0;
        }
      });
    },

positionsArray 输出

[
  {
    flagged: false,from: 2019-10-31T23:00:00.000Z,to: 2020-01-31T23:00:00.000Z,title: 'junior manual tester'
  },{
    flagged: false,from: 2018-05-31T22:00:00.000Z,to: 2019-09-30T22:00:00.000Z,title: 'junior administrator'
  },from: 2016-03-31T22:00:00.000Z,to: 2016-03-31T22:00:00.000Z,title: 'praktykant'
  }
]

带子串的输入

    "titlesIncluded": [
        "qa","quality engineer","qa automation","software tester","qa engineer"
    ],

解决方法

我找不到用 reduce() 方法来做到这一点的方法,但我已经用我的菜鸟方法做到了。我正在做的基本上是创建新对象并按属性标题过滤,然后将每个对象推送到数组中并进行适当的数学运算。代码如下:

    calculateSoftwareExperience: async function () {
      fileToCurate.forEach(candidate => {
        const positionsArray = candidate.softwareIndustryPositions;

        if (Array.isArray(positionsArray) && positionsArray.length) {
          let roletypeArray = [];
          positionsArray.forEach(position => {
            let title = position.title;
            if (titlesIncluded.some(x => title.includes(x))) {
              let pos = {};
              pos.title = title;
              pos.from = position.from;
              pos.to = position.to;
              roletypeArray.push(position);
            }
          });

          if (Array.isArray(roletypeArray) && roletypeArray.length) {
            const firstFrom = roletypeArray[roletypeArray.length - 1].from;
            const lastTo = roletypeArray[0].to;
            let diff = lastTo - firstFrom;
            let days = (diff * 1000) / (60 * 60 * 24 * 1000) / 1000;
            let months = Math.floor(days / 31);
            candidate.softwareIndustryExp = months;
          } else {
            candidate.softwareIndustryExp = 0;
          }
        } else {
          candidate.softwareIndustryExp = 0;
        }
      });
    },

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。