gpt4 book ai didi

javascript - 排序时保留 JSON 数组

转载 作者:可可西里 更新时间:2023-10-31 22:48:40 24 4
gpt4 key购买 nike

我有两个来自外部网站的 JSON 数组。我对这两个数组进行排序和合并,对它们进行解码,然后按 ID 从高到低对它们进行排序。

目前,当点击“alphabetical”选项时,?sort=alphabetical 被添加到 URL 的末尾,当页面完成重新加载时,JSON 数组再次被解码和合并.

这不是我想要的结果:我不希望在单击该选项时再次解码和合并 JSON 数组 - 我只是希望按字母顺序对已经解码和合并的 JSON 数组进行排序。


数组:

$homepage = array();  

$homepage[]= '{
"info":{
"collection":[
{
"Name":"Charlie",
"ID":"7"
},
{
"Name":"Emma",
"ID":"9"
}
]
}
}';

$homepage[] = '{
"info":{
"collection":[
{
"Name":"Bob",
"ID":"5"
}
]
}
}';

排序:

$data = array();
foreach ($homepage as $homepage2) {
$tmp=json_decode($homepage2, false);
$data = array_merge($data,$tmp->info->collection);
}

if(!empty($_GET['sort']) && $_GET['sort'] == 'alphabetical') {
usort($data, function ($a, $b) {
return strcmp($a->Name, $b->Name);
});
}else{
usort($data, function ($a, $b) {
return $b->ID - $a->ID;
});
}

echo'
<select onchange="location.href = this.value;">
<option value="example.php?sort=alphabetical">Alphabetical</option>
</select>
';

foreach($data as $key) {
echo'
<a href="test.com">
<p>'.$key->ID.'</p>
<p>'.$key->Name.'</p>
</a>
';
}

最佳答案

您可以使用 JavaScript 在点击时进行排序,而仅使用 PHP 将 JSON 传递给它。

在您提供了要在其中显示列表的 HTML 结构后,我更新了此答案,以使用 div 元素作为记录,使用 p 元素作为字段。

我们可以用两个按钮替换 select 列表,用于选择排序顺序。

这是 PHP 代码:

<?php

$homepage = array();

$homepage[]= '{
"info":{
"collection":[
{
"Name":"Charlie",
"ID":"13"
},
{
"Name":"Emma",
"ID":"9"
}
]
}
}';

$homepage[] = '{
"info":{
"collection":[
{
"Name":"Bob",
"ID":"10"
}
]
}
}';

$data = array();
foreach ($homepage as $homepage2) {
$tmp=json_decode($homepage2, false);
$data = array_merge($data,$tmp->info->collection);
}

?>

<div id="container"></div>

<button id="sort1">Alphabetical</button>
<button id="sort2">High to Low</button>

<script>
var collection = <?=json_encode($data)?>;

function populate(compareFunc) {
collection.sort(compareFunc);
var container = document.getElementById('container');
container.innerHTML = '';
collection.forEach(function (key) {
var div = document.createElement("div");
div.className = "inventory";
var span = document.createElement("span");
span.textContent = key.ID;
div.appendChild(span);
span = document.createElement("span");
span.textContent = key.Name;
div.appendChild(span);
container.appendChild(div);
});
}

var populateById = populate.bind(null, function (a, b) {
return a.ID - b.ID;
});

var populateByName = populate.bind(null, function (a, b) {
return a.Name.localeCompare(b.Name);
});

document.getElementById("sort1").addEventListener('click', populateByName);
document.getElementById("sort2").addEventListener('click', populateById);
document.addEventListener('DOMContentLoaded', populateById);

</script>

对于示例数据,这将生成以下 JavaScript/HTML,您可以在此处对其进行测试:

var collection = [{"Name":"Charlie","ID":"13"},{"Name":"Emma","ID":"9"},{"Name":"Bob","ID":"10"}];

function populate(compareFunc) {
collection.sort(compareFunc);
var container = document.getElementById('container');
container.innerHTML = '';
collection.forEach(function (key) {
var div = document.createElement("div");
div.className = "inventory";
var span = document.createElement("span");
span.textContent = key.ID;
div.appendChild(span);
span = document.createElement("span");
span.textContent = key.Name;
div.appendChild(span);
container.appendChild(div);
});
}

var populateById = populate.bind(null, function (a, b) {
return a.ID - b.ID;
});

var populateByName = populate.bind(null, function (a, b) {
return a.Name.localeCompare(b.Name);
});

document.getElementById("sort1").addEventListener('click', populateByName);
document.getElementById("sort2").addEventListener('click', populateById);
document.addEventListener('DOMContentLoaded', populateById);
span { margin-left: 5px }
div.inventory { border-bottom: 1px solid gray }
<div id="container"></div>

<button id="sort1">Alphabetical</button>
<button id="sort2">High to Low</button>

请注意,我为这三个项目提供了与您问题中不同的 ID 值,否则 ID 和名称的排序顺序将相同。

使用表格:替代方法

有一些不错的 JavaScript 库可以提供更多的特性来表示数据集。这是一个将 jQuery 与 DataTables 结合使用的示例:

var collection = [{"Name":"Charlie","ID":"13"},{"Name":"Emma","ID":"9"},{"Name":"Bob","ID":"5"}];

function populate() {
var tbody = $('#collection>tbody');
collection.forEach(function (key) {
var row = $('<tr>');
row.append($('<td>').text(key.ID));
row.append($('<td>').text(key.Name));
tbody.append(row);
});
}

$(document).ready(function(){
populate();
$('#collection').DataTable();
});
<script src="http://code.jquery.com/jquery-1.12.3.js"></script>
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.12/css/jquery.dataTables.min.css">
<script src="https://cdn.datatables.net/1.10.12/js/jquery.dataTables.min.js"></script>

<table id="collection">
<thead>
<tr><th>ID</th><th>Name</th></tr>
</thead>
<tbody/>
</table>

实际代码甚至比使用基本表的纯 JavaScript 解决方案更小(不包括包含的库)。但这有上下排序,过滤,分页,漂亮的样式,......

关于javascript - 排序时保留 JSON 数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37863071/

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