如何使用数组制作对象数组

how to make array of object using an array?

本文关键字:数组 对象 作对 何使用      更新时间:2023-09-26

我有一个数组

var ar=['aa','cc','po']

我想在检查给定数组的值后,将对象推送到新数组中。换句话说,

我有这些给定的条件

var ar=['aa','cc','po']
var arr =[{name:"po"},{name:'aa'},{name:'cc'}];

新阵列中的预期输出

  [{name:'aa'},{name:'cc'},{name:"po"}]

作为0索引中的"aa",我添加了名称属性为aa的对象。

我试着这样做。但我用了两个作为外观。有什么简单的方法可以做这个吗

小提琴

var newArr=[];
for(var i=0;i<ar.length ;i++){
   var text =ar[i];
   for(var j=0;j<arr.length ;j++){
    var obj =arr[j];
    console.log(obj.name);
     /*if(obj.name===text){
       newArr.push(obj);
     }*/
    }
}
console.log(newArr);  

这是一个分为两部分的建议,首先用arr的项建立一个对象,然后用ar的给定项创建一个新数组。

var ar = ['aa', 'cc', 'po'],
    arr = [{ name: "po" }, { name: 'aa' }, { name: 'cc' }],
    object = Object.create(null),
    result = [];
arr.forEach(function (a) {
    object[a.name] = a;
});
ar.forEach(function (a) {
    object[a] && result.push(object[a]);
});
document.write('<pre>' + JSON.stringify(result, 0, 4) + '</pre>');

使用forEach迭代器并根据名称生成对象引用,然后使用map()生成结果数组

var ar = ['aa', 'cc', 'po']
var arr = [{
  name: "po"
}, {
  name: 'aa'
}, {
  name: 'cc'
}];
var ref = {};
// generating object reference with name property
arr.forEach(function(v) {
  ref[v.name] = v;
});
// generating result array 
// or you can use forEach as @NinaScholz answer
var res = ar.map(function(v) {
  return ref[v];
}).filter(function(v) { // use filter to avoid null values , in case of missing elements
  return v != null;
});
document.write('<pre>' + JSON.stringify(res, null, 3) + '</pre>');

试试这个:

function convert(source) {
  var 
    obj = [],
    i;
  for (i = 0; i < source.length; ++i) {
    obj.push({name: source[i]});
  }
  return obj;
}
convert(['aa', 'bb', 'cc']); // [{name:'aa'},{name:'bb'},{name:'cc'}]

如果您想按顺序从数组分配值,这将起作用:

var ar=['aa','cc','po']
var arr =[{name:"po"},{name:'aa'},{name:'cc'}];
arr.map(function(obj,key){
    obj.name = ar[key];
});
console.log(arr);

喜欢这个

var ar = ['aa', 'cc', 'po']
var arr = [{  name: "po"}, {  name: 'aa'}, {  name: 'cc'}];
$.each(ar, function(i, v) {
  arr[i].name = v;
});
console.log(arr)

Fiddle

var array=['a','b','c'];
var arrayObj=[];
for(var i=0;i<array.length;i++){
 var obj={};
 obj.name=array[i];
 arrayObj.push(obj);
}
console.log(JSON.stringify(arrayObj));

输出:[{"name":"a"}、{"name":"b"},{"name=":"c"}]

我想这是一种非常实用的方法,只需要一行赋值就可以完成这项工作。然而,如果ar阵列的长度短于arr阵列的长度,Anoop Joshi的答案会更优雅。

var arr = ['aa','cc','po'],
     ar = [{name:"po"},{name:'aa'},{name:'cc'}],
    res = arr.map(e => ar[ar.findIndex(f => f.name == e)]);
document.write("<pre>" + JSON.stringify(res) + "</pre>");