繁体   English   中英

在通过所有页面获取数据后,如何循环排序来自 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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM