如何解决JS reduce:对象累加器标题
我现在正在试验reduce函数,想知道是否可以将累加器的键名定制为特定值?
例如,以下代码返回{16年的经验:...},但我希望将返回结果归类如下:
Results wanted in this format:
{ Over 10 years:
16: {
{name: "Company One",category: "Finance",start: 1981,end: 2003},{name: "Company Two",category: "Retail",start: 1992,end: 2008}
},20: {
{name: "Company One",end: 2008}
}
...
} etc...
const companies = [
{name: "Company One",end: 2008},{name: "Company Three",category: "Auto",start: 1999,end: 2007},{name: "Company Four",start: 1989,end: 2010},{name: "Company Five",category: "Technology",start: 2009,end: 2014},{name: "Company Six",start: 1987,{name: "Company Seven",start: 1986,end: 1996},{name: "Company Eight",start: 2011,end: 2016},{name: "Company Nine",end: 1989}
];
const industryExeperience = (obj,keyStart,keyEnd)=>{
return obj.reduce((exp,curObj)=>{
let differences = curObj[keyEnd] - curObj[keyStart];
console.log(differences)
if(differences > 10){
exp[differences + ' years of experience'] = curObj
}
return exp
},{})
}
console.log(industryExeperience(companies,'start','end'))
解决方法
要按年份分组,请使用差值作为键,并使用数组作为值。 将每一项推入或合并到现有阵列中,或根据需要添加新项
const companies = [
{name: "Company One",category: "Finance",start: 1981,end: 2003},{name: "Company Two",category: "Retail",start: 1992,end: 2008},{name: "Company Three",category: "Auto",start: 1999,end: 2007},{name: "Company Four",start: 1989,end: 2010},{name: "Company Five",category: "Technology",start: 2009,end: 2014},{name: "Company Six",start: 1987,{name: "Company Seven",start: 1986,end: 1996},{name: "Company Eight",start: 2011,end: 2016},{name: "Company Nine",end: 1989}
];
const grouped = companies.reduce((a,c)=>{
const diff = c.end - c.start;
a[diff] = (a[diff] || []).concat(c)
return a;
},{})
console.log(grouped)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。