在 JavaScript 中多次乘/克隆对象内部和数组

如何解决在 JavaScript 中多次乘/克隆对象内部和数组

具有这种格式的对象数组:

const data = [
{country_id: 1,country: "Greece",value: 3},{country_id: 2,country: "Cyprus",value: 2},{country_id: 3,country: "Turkey",value: 4}
]

如何使用 JavaScript 乘以/克隆每个对象以获取以下对象数组?我想将每个对象乘以 value 中指定的次数并获得一个新数组。

const new_data = [
{id: 1,country_id: 1,{id: 2,{id: 3,{id: 4,country_id: 2,{id: 5,{id: 6,country_id: 3,value: 4},{id: 7,{id: 8,{id: 9,value: 4}
]

到目前为止,我最好的尝试是使用 Object.assign,但不幸的是,该映射返回的数组与 data 中的数组相同:

const new_data = data.map((d,i) => {
    for (var i = 0; i < d.mult; ++i) {
      Object.assign({},d[i]);
    }
    return d;
 })

解决方法

您可以这样做,只需用 value 元素填充数组,并将其映射到原始元素的副本:

const data = [
{country_id: 1,country: "Greece",value: 3},{country_id: 2,country: "Cyprus",value: 2},{country_id: 3,country: "Turkey",value: 4}
]

console.log(
    data.flatMap((el) => new Array(el.value).fill(null).map(e => ({...el}))))

,

您可以使用 Array.from()reduce 来完成。试试这个-

在这里您可以使用 Array.from({length: X}) 创建一个临时数组。这里的 {length: X} 对象表示使用 from 方法创建一个长度为 X 的数组。

之后,Array.from() 方法的回调函数每次迭代都会返回当前项。就是这样。

const data = [
  {country_id: 1,value: 4}
];

const res = data.reduce((acc,curr) => {
  const tmp = Array.from({length: curr.value},() => curr);
  acc.push(...tmp);
  return acc;
},[]);

console.log(JSON.stringify(res));
.as-console-wrapper{min-height: 100%!important; top: 0}

,

最简单的方法是创建一个新数组,循环遍历旧数组并将重复项(使用新的 id 字段)添加到结果数组中:

const data = [
    { country_id: 1,value: 3 },{ country_id: 2,value: 2 },{ country_id: 3,value: 4 }
]

const result = [];

let id = 0;
for (const row of data) {
    for (let i = 0; i < row.value; i++) {
        const newRow = {
            ...row,// copy old data
            id: ++id,// but set this field and increase `id`
        };
        result.push(newRow);
    }
}

console.log(result);

如果您想使用 .map 之类的内容,您需要使用 .flatMap.map 后跟 .flat()。您的(平面)地图将返回一个包含 value 新行的数组。不过,您仍然需要修复 country_id

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?