如果我有一个字符串数组,我可以使用.join()方法获得一个字符串,每个元素用逗号分隔,如下所示:
["Joe", "Kevin", "Peter"].join(", ") // => "Joe, Kevin, Peter"
我有一个对象数组,我想对其中的值执行类似的操作;所以从
[
{name: "Joe", age: 22},
{name: "Kevin", age: 24},
{name: "Peter", age: 21}
]
只对name属性执行join方法,以实现与前面相同的输出。
目前我有以下功能:
function joinObj(a, attr){
var out = [];
for (var i = 0; i < a.length; i++){
out.push(a[i][attr]);
}
return out.join(", ");
}
这段代码没有什么问题,它可以工作,但突然之间,我从简单、简洁的代码行变成了一个非常命令式的函数。有没有更简洁,更实用的写法呢?
试试这个
var x= [
{name: "Joe", age: 22},
{name: "Kevin", age: 24},
{name: "Peter", age: 21}
]
function joinObj(a, attr) {
var out = [];
for (var i=0; i<a.length; i++) {
out.push(a[i][attr]);
}
return out.join(", ");
}
var z = joinObj(x,'name');
z > "Joe, Kevin, Peter"
var y = joinObj(x,'age');
y > "22, 24, 21"
我也遇到过reduce方法,它是这样的:
console.log (
[
{名字:“乔”,年龄:22岁},
{姓名:“凯文”,年龄:24},
{姓名:“彼得”,年龄:21岁}
]
.reduce(函数(a, b) {
返回(a.name || a) + ", " + b.name}
)
)
(a.name || a)因此第一个元素被正确处理,但其余(其中a是字符串,因此a.name是未定义的)不被视为对象。
编辑:我现在进一步重构了它:
x.reduce(function(a, b) {return a + ["", ", "][+!!a.length] + b.name;}, "");
我相信这是干净的,因为a始终是一个字符串,b始终是一个对象(由于使用可选的initialValue参数在减少)
6个月后编辑:哦,我在想什么。“清洁”。我激怒了代码之神。