gpt4 book ai didi

javascript - Underscore.js 根据值重新构造对象

转载 作者:行者123 更新时间:2023-12-02 19:35:47 26 4
gpt4 key购买 nike

我正在使用 underscore.js,当然任何解决方案都可以,但我有一个如下所示的对象:

{ '4f871d4967e04': 
[ { _id: 4f871d4adaf6fa492f000001,
product_id: 4f871d43daf6fa4e2f000002,
width: '300',
height: 300,
group: '4f871d4967e04' },
{ _id: 4f871d4adaf6fa492f000004,
product_id: 4f871d43daf6fa4e2f000002,
width: '150',
height: 150,
group: '4f871d4967e04' },
{ _id: 4f871d4bdaf6fa492f000007,
product_id: 4f871d43daf6fa4e2f000002,
width: '100',
height: 100,
group: '4f871d4967e04' },
{ _id: 4f871d4bdaf6fa492f00000a,
product_id: 4f871d43daf6fa4e2f000002,
width: '75',
height: 75,
group: '4f871d4967e04' } ],
'4f871d51200de':
[ { _id: 4f871d51daf6faf42e000001,
product_id: 4f871d43daf6fa4e2f000002,
width: '300',
height: 300,
group: '4f871d51200de' },
{ _id: 4f871d52daf6faf42e000004,
product_id: 4f871d43daf6fa4e2f000002,
width: '150',
height: 150,
group: '4f871d51200de' },
{ _id: 4f871d53daf6faf42e000007,
product_id: 4f871d43daf6fa4e2f000002,
width: '100',
height: 100,
group: '4f871d51200de' },
{ _id: 4f871d53daf6faf42e00000a,
product_id: 4f871d43daf6fa4e2f000002,
width: '75',
height: 75,
group: '4f871d51200de' } ] }

我想把它变成这样:

{"4f871d4967e04" : {
"300" : {
_id : '',
}
"150" : {
_id : '',
}
"100" : {
_id : '',
}
"75" : {
_id : '',
}
}, "4f871d4967e04" : {
"300" : {
_id : '',
}
"150" : {
_id : '',
}
"100" : {
_id : '',
}
"75" : {
_id : '',
}
}

这样我就可以迭代每个“组”并简单地使用 this["300"] 来获取我想要的大小。我在 Handlebar 的模板中对此进行迭代,因此我只能检查哪些条件。

任何建议都会非常有帮助。

谢谢!

最佳答案

明显的简单 JavaScript 方法可能是最快的:

var want = { };
var k, i, o;
for(k in data) {
want[k] = { };
for(i = 0; i < data[k].length; ++i) {
o = data[k][i];
want[k][o.width] = o;
}
}

只需逐个键循环遍历主对象(data),并使用内部循环将数组重新排列为宽度→对象映射表。

你想出的任何东西都可能是伪装的嵌套循环。下划线版本看起来像这样:

var want = _(data).reduce(function(outer, v, k) {
outer[k] = _(v).reduce(function(inner, o) {
inner[o.width] = o;
return inner;
}, { });
return outer;
}, { });

这几乎就是用 reduce 设置的原始嵌套 for 循环。代替循环。您在此处使用 reduce 的能力几乎受到限制,因为大多数 Underscore 函数确实希望将所有内容都转换为数组。您可以使用 each :

var want = { };
_(data).each(function(v, k) {
var inner = { };
_(v).each(function(o) {
inner[o.width] = o;
});
want[k] = inner;
});

但这与使用临时变量的 reduce 方法相同。您可能会想出其他方法,但它们可能只是这个主题的更多变体。

演示:http://jsfiddle.net/ambiguous/ffcUC/2/

<小时/>

如果您想将数据发送到 Handlebars 模板,例如:

{{#each images}}<img src="../{{this.300._id}}" />{{/each}}

那么您只需要上面生成的值。但在这种情况下,您可以调整循环以节省一些工作:

var want = [ ];
var k, i, o;
for(k in data) {
o = { };
for(i = 0; i < data[k].length; ++i) {
o[data[k][i].width] = data[k][i];
}
want.push(o);
}
return want;

或者切换到 map 内的 reduce :

var index_by_height = function(o) {
return _(o).reduce(function(memo, i) {
memo[i.height] = i;
return memo;
}, { });
};
return _.chain(data)
.values()
.map(index_by_height)
.value();

演示:http://jsfiddle.net/ambiguous/tsx7z/

关于javascript - Underscore.js 根据值重新构造对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10940002/

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