gpt4 book ai didi

javascript - jQuery:从由特定键分隔的 json 对象构建 ui

转载 作者:行者123 更新时间:2023-12-03 11:06:58 24 4
gpt4 key购买 nike

我的 ajax 函数返回几个具有以下模式的 JSON 对象:

var data = [
{ 'category': 3, 'name': 'Max' },
{ 'category': 1, 'name': 'John' },
{ 'category': 2, 'name': 'Mary' },
{ 'category': 2, 'name': 'Dennis' },
{ 'category': 1, 'name': 'Louis' }
];

同一类别的对象可以有不同的名称。

我的目标是使用 jQuery 根据这些按类别排序的对象建立一个列表。列表最终应如下所示:

<ul class="list">
<li class="category-divider">1</li>
<li class="element">John</li>
<li class="element">Louis</li>
<li class="category-divider">2</li>
<li class="element">Mary</li>
<li class="element">Dennis</li>
<li class="category-divider">3</li>
<li class="element">Max</li>
</ul>

基于上面提供的数组构建此列表的最快且最灵活的方法是什么?

最佳答案

var data = [{
'category': 3,
'name': 'Max'
}, {
'category': 1,
'name': 'John'
}, {
'category': 2,
'name': 'Mary'
}, {
'category': 2,
'name': 'Dennis'
}, {
'category': 1,
'name': 'Louis'
}];


var list = $("<ul></ul>") // create list
var groupedData = {};
for (var i = 0; i < data.length; i++) { // group names by category
groupedData[data[i].category] = groupedData[data[i].category] || []; // check if it exists, if not set it as empty array
groupedData[data[i].category].push(data[i].name)
}

var categories = Object.keys(groupedData).sort(function(a,b){ return a -b}) // sort categories

for (var j = 0; j < categories.length; j ++) {
var cat = categories[j]
var category = $("<li class='category-divider'>" + cat + "</li>") // create category divider
for (var i = 0; i < groupedData[cat].length; i++) {
category.append("<li class='element'>" + groupedData[cat][i] + "</li>") // add names
}
list.append(category) // add category to list
}
$("body").append(list) // add list to body
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>

关于javascript - jQuery:从由特定键分隔的 json 对象构建 ui,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27805620/

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