繁体   English   中英

将对象添加到Java列表中

[英]Adding Objects to List in Javascript

我得到以下数据:

参考文献列表:

[{
    name: "dog", present: false
}, {
    name: "cat", present: true
}, {
    name: "bird", present: false
}]

给定列表:

["dog, cat"]

想要的结果:

[{
    name: "dog", present: true
}, {
    name: "cat", present: true
}, {
    name: "bird", present: false
}]

现在,我可以通过创建3个条件语句并执行indexOf来生成Wanted Result。 但是,我想知道是否有一种方法可以通过lodash之类的东西在1行中完成全部操作。

那是你需要的吗?

let reference = [{name:"dog", present:false}, {name:"cat", present:true}, {name:"bird", present:false }];
let list = ['dog', 'cat'];

let result = reference.map(item => ({
  name: item.name,
  present: list.indexOf(item.name) !== -1
}));

console.log(result);

从逻辑.map ,它只是使用.map函数来完成您编写的操作。

使用Array.prototype.forEach()Array.prototype.indexOf()函数的最短解决方案:

 var data = [{ name: "dog", present: false }, { name: "cat", present: true }, { name: "bird", present: false }], f = ["dog", "cat"]; data.forEach(function (o) { o.present = (f.indexOf(o.name) !== -1); }); console.log(data); 

您可以使用Array.map()

 var reflist = [{ name: "dog", present: false }, { name: "cat", present: true }, { name: "bird", present: false }]; var givenList = ["dog", "cat"]; reflist = reflist.map(function(elem){ if(givenList.indexOf(elem.name) !== -1) elem.present = true; return elem; }); console.log(reflist); 

只是另一种方式。

 var fields = [{ name: "dog", present: false }, { name: "cat", present: true }, { name: "bird", present: false }]; console.log(fields); ['dog', 'cat'].forEach(function (value) { fields.forEach(function (k) { if (k.name === value) { k.present = true; } }); }); console.log(fields); 

您需要循环引用数据的项目,将每个项目与给定的项目集进行比较,并构建一个新的对象数组。

var wantedResult = [];
var keys = Object.keys(refData);
for(var i=0; i<keys.length; i++) {
    wantedResult.push({
        name:refData[keys[i]].name,         
        present:givenList.indexOf(refData[keys[i]].name) != -1
    });
}

这是您的一线客:

referenceList.map((e) => { e.present = givenList.indexOf(e.name) > -1;})

请注意,您将修改referenceList ,此行的返回值对您没有用。 这只是undefined的列表

参考

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM