如果我有一个字符串数组,我可以使用.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(", ");
}

这段代码没有什么问题,它可以工作,但突然之间,我从简单、简洁的代码行变成了一个非常命令式的函数。有没有更简洁,更实用的写法呢?


当前回答

简单的方法:

const oldArrayOfObjects = [ {姓名:“鲍勃”,年龄:40}, {姓名:“安德鲁”,年龄:25}, {姓名:“Peter”,年龄:30}]; const newArrayOfStringNames = oldArrayOfObjects.map((OA) => OA.name); const newArrayOfAges = oldArrayOfObjects.map((OA) => OA.age); console.log ({newArrayOfStringNames, newArrayOfAges})

其他回答

这招对我很管用:

var users = [
      {name: "Joe", age: 22},
      {name: "Kevin", age: 24},
      {name: "Peter", age: 21}
    ]

 return users.map((user: { name: string; }) => user.name).join(", ");

简单的方法:

const oldArrayOfObjects = [ {姓名:“鲍勃”,年龄:40}, {姓名:“安德鲁”,年龄:25}, {姓名:“Peter”,年龄:30}]; const newArrayOfStringNames = oldArrayOfObjects.map((OA) => OA.name); const newArrayOfAges = oldArrayOfObjects.map((OA) => OA.age); console.log ({newArrayOfStringNames, newArrayOfAges})

你总是可以重写对象的toString方法:

Var arr = [ {name: "Joe",年龄:22岁,toString: function(){返回this.name;}}, {name:“Kevin”,年龄:24,toString: function(){返回this.name;}}, {name: "Peter",年龄:21岁,toString: function(){返回this.name;}} ]; Var结果= arr。加入(","); console.log(结果);

假设对象数组由变量users引用

如果ES6可以使用,那么最简单的解决方案将是:

users.map(user => user.name).join(', ');

如果不是,和lodash可以这样使用:

 _.map(users, function(user) {
     return user.name;
 }).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"