gpt4 book ai didi

javascript - 重构 Javascript 数组

转载 作者:行者123 更新时间:2023-11-29 23:03:26 25 4
gpt4 key购买 nike

编辑:感谢您的回复!

我是使用 Javascript 的新手(抱歉可能是错误的代码)。我主要只使用 HTML 和 CSS。我一直在尝试使用 Javascript 进行试验,但我一直坚持这一点。结果不是我想要的。

我的代码:

我想通过将值放在同一类别下使数组更易于使用,但我的代码输出与我想要的不完全一样。

var data = {
idName: "idName",
valueRanges: [{
range: "range",
majorDimension: "ROWS",
values: [
[
"ID",
"Category",
"Name"
],
[
"1",
"Category1",
"Name1"
],
[
"2",
"Category1",
"Name2"
],
[
"3",
"Category2",
"Name3"
],
[
"4",
"Category1",
"Name4"
]
]
}]
}

var rows = [];

let batchRowValues = data.valueRanges[0].values
for (let i = 1; i < batchRowValues.length; i++) {
let rowObject = {};
for (let j = 0; j < batchRowValues[i].length; j++) {
rowObject[batchRowValues[0][j]] = batchRowValues[i][j];
}
rows.push(rowObject);
}

var newArray = rows.reduce(function(acc, curr) {
var findIfNameExist = acc.findIndex(function(item) {
return item.Category === curr.Category;
})
if (findIfNameExist === -1) {
let obj = {
'Category': curr.Category,
'value': [curr]
}
acc.push(obj)
} else {
acc[findIfNameExist].value.push(curr)
}
return acc;
}, []);

console.log('------------')
console.log('input: ' + JSON.stringify(data, null, 2))
console.log('------------')
console.log('output: ' + JSON.stringify(newArray, null, 2))

我的代码输出:

[
{
Category: "Category1",
value: [
{
Category: "Category1",
ID: "1",
Name: "Name1"
},
{
Category: "Category1",
ID: "2",
Name: "Name2"
},
{
Category: "Category1",
ID: "4",
Name: "Name4"
}
]
},
{
Category: "Category2",
value: [
{
Category: "Category2",
ID: "3",
Name: "Name3"
}
]
}
]

我希望它看起来如何:

[
{
Category: "Category1",
values: [
{
ID: "1",
Name: "Name1"
},
{
ID: "2",
Name: "Name2"
},
{
ID: "4",
Name: "Name4"
}
]
},
{
Category: "Category2",
values: [
{
ID: "3",
Name: "Name3"
},
]
},
]

我要学习!我感谢任何帮助。

最佳答案

你可以使用reduce。

思路是

  • 创建一个对象并使用类别作为键
  • 如果已找到一个类别,则将所需的对象推送到它的值属性中。如果不是,我们会用合适的数据创建一个新的。

我在这里使用对象而不是直接使用数组是因为我可以使用键直接访问元素,而在数组中我需要每次循环并检查值是否存在

var data = {idName: "idName",valueRanges: [{range: "range",majorDimension: "ROWS",values: [["ID","Category","Name"],["1","Category1","Name1"],["2","Category1","Name2"],["3","Category2","Name3"],["4","Category1","Name4"]]}]}

var rows = [];
let batchRowValues = data.valueRanges[0].values.slice(1,)

let op = batchRowValues.reduce((op,[ID,Category,Name]) => {
if( op[Category] ){
op[Category].value.push({ID,Name})
} else {
op[Category] = {
Category,
value: [{ID,Name}]
}
}
return op
},{})

console.log(Object.values(op))

关于javascript - 重构 Javascript 数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55171036/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com