首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >基于对象内部数组的新对象数组?

基于对象内部数组的新对象数组?
EN

Stack Overflow用户
提问于 2016-08-19 04:55:42
回答 3查看 70关注 0票数 0

需要基于数组的元素创建对象的浅数组,数组的元素是对象的值:

代码语言:javascript
运行
复制
var obj = {
  a: 1,
  b: 'x',
  c: 'z',
  d: ['rr', 'qq']
};

var rec = [];

obj.d.forEach(function(e, i) {
  rec.push({
    d: e
  })
});

console.log(rec);

但当然这只会让我

代码语言:javascript
运行
复制
[ { d: 'rr' }, { d: 'qq' } ]

如何在新的对象数组中实现这一点?-->

代码语言:javascript
运行
复制
[ { a: 1,
    b: 'x',
    c: 'z',
    d: 'rr' }, 
  { a: 1,
    b: 'x',
    c: 'z',
    d: 'qq' } ]
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-08-19 04:57:22

获得所需结果的最简单方法是使用map函数(它使用给定的映射函数将一个数组的元素映射到一个新数组)。然后,您可以使用来自原始对象的abc以及来自映射函数参数的d来创建新对象:

代码语言:javascript
运行
复制
var rec = obj.d.map(function(r) {
  return { 
    a: obj.a, 
    b: obj.b, 
    c: obj.c, 
    d: r 
  };
});
票数 4
EN

Stack Overflow用户

回答已采纳

发布于 2016-08-19 04:57:22

代码语言:javascript
运行
复制
obj.d.forEach(function(e) {
    var item = {};

    Object.keys(obj).forEach(function(key) {
        item[key] = obj[key];
    });

    item.d = e;

    rec.push(item);
});

但是属性a,b,c不能是对象。否则,rec数组中的每一项都将具有相同的引用。

票数 4
EN

Stack Overflow用户

发布于 2016-08-20 12:00:36

或者,这是可行的,但它相当丑陋:

代码语言:javascript
运行
复制
var o = {
  a: 1,
  b: 'x',
  c: 'z',
  d: ['rr', 'qq']
};

var arr = [];

Object.keys(o).forEach(function(k) {
    var val = o[k];
    if (Array.isArray(val)) {
        val.forEach(function(j) {
        arr.push({[k] : j});
        });
    }
});

arr.forEach(function(obj) {
    for (var p in o) {
        var val = o[p];
        if (!Array.isArray(val)) {
        obj[p] = val
        }
    }
});

console.log(arr);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39027359

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档