[英]How to sort data already fetched from database with jquery/ajax?
[英]How to loop sort data coming from ajax calls after data has already been fetched through ALL pages?
我无法通过循环对数组进行排序。 它每 20 个元素部分工作(逐页排序)。
是否可以循环浏览网站中的所有页面?
大约需要 10 次 Ajax 调用来获取所有数据(2000 项)。
在下面的代码中,我查询通过 Ajax 获取数据,它工作正常:
<script language="javascript">
var current_page = 1, count = 100;
$(function(){
setTimeout(function(){
newSearch();
}, 0);
});
function newSearch() {
count = 0;
current_page = 1;
$('#main').html('');
doSearch();
}
function doSearch(){
$.ajax({
url:'https://live.ksmobile.net/live/boys?'
data: {
page_size: 900,
page_index: current_page
},
cache: false,
type: 'GET',
dataType: 'json',
success: function(r){
var max = $('#limit').val();
if (r.data.video_info.length < max) max =r.data.video_info.length;
for (index = 0; index < max; index++) {
var entry = r.data.video_info[index];
var level = parse Int(entry.level);
if ((level > $('#min').val()) && (level < $('#max').val())) {
count++;
var HTML = '<div class="entry ' + '"><h="' + entry + '">';
HTML += '<h3>Level: <span>' + entry.level + '</span> <span>' + entry.name + '' + '</span>id:<span>' + entry.heat;
HTML += '</div>';
$('#main').append(HTML);
下面排序 function 中的问题,它仅适用于每个页面,而我需要在主页中按(级别)对所有元素进行排序。
function arr(a,b) {
return parseInt(a.level, 10) - parseInt(b.level, 10);
}
r.data.video_info.sort(arr);
}
if ((current_page < 100) && (count < $('#limit').val() )) {
current_page++;
setTimeout(function(){
doSearch();
},0);
}
}
});
}
我想将网站的所有页面(已排序)显示为我的主页的一部分。 非常感谢您的帮助。
不应该在 javascript 中对分页数据进行排序。 您需要编辑后端查询以从那里对其进行排序。 此外,仅为了排序而获取所有页面的数据是一个非常糟糕的主意,因为它会破坏分页的目的,并且会给您的 API 调用造成巨大的延迟,尤其是在您有大量数据要获取的情况下。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.