新闻中心 网络推广 网站建设 优化推广

PB通过API接口,实现Ajax无刷新加载内容,下滑自动加载更多新闻

时间:2019-08-07   来源:本站

这个内容是官网上发的,不过那个上面写得不是很清楚,特别整理一下重新发布。希望对大家有所作用


弟一:引入JS

<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>

第二:    <!------------定义内容的Dom位置----------------->
  <div class="mylist">
    {pboot:list   num=2 order='sorting asc'}
     <div class="title"><a href="[list:link]">[list:title]</a></div>
    <div class="desc">[list:description]</div>
    <hr>
    {/pboot:list}
          
</div>

     
 第三:添加按钮
            
<button id="More" type="submit">点击加载更多</button> 



第四:添加JS

<script>
//先定义一些基本的内容

//Page就是第几页,由当前页0 + 1,就是第二页,parseInt确保该数值是Int类型。
var Page = parseInt('1') + 1;

//Num就是每页几条信息,因为列表默认显示的是2条,所以这里设为2,结合上面的第二页实际上就是从第三条信息开始读取。
var Num  = 5;

//定义内容的Dom位置,也就是读取出来的内容要添加到哪个div里面去。
var Dom  = jQuery('.mylist');


    //使用jQuery的scroll()方法来监听页面滚动
jQuery(window).scroll(function(){

    //当前窗口和页面顶部的距离
    var WindowTop = jQuery(window).scrollTop();
    
    //可视窗口区域高度
    var WindowHeight = jQuery(window).outerHeight();
    
    //页面的高度
    var DocHeight = jQuery(document).height();
    
    //定义一个开关
    var load = true;
    
    //判断:(窗口与页面顶部距离 + 窗口高度) >= 页面的高度(也就是滚动到页面底部的时候),并且开关是开启状态,执行ajax加载内容
    if( ( WindowTop + WindowHeight ) >= DocHeight && load == true ){
    
        //请求地址
       
         var url = '/api.php/list/2/page/' + Page + '/num/' + Num;
        
        //设置开关状态为关闭,防止重复加载
        load = false;
        
       //开始Ajax提交请求,请求路径就是Api接口
    jQuery.ajax({
        //请求类型
        type: 'POST', 
        //请求地址
        url: url,
        //返回数据类型
        dataType: 'json',
        //请求参数,参考官方Api手册,在站内使用以下参数会自动获取
        data: {
            appid: '{pboot:appid}',
            timestamp: '{pboot:timestamp}',
            signature: '{pboot:signature}',
        },
        //请求成功
            
            success: function( response, status ){
                
                var Data = response.data;
                
                if( response.code ){
                    
                    //获取数据成功
                    jQuery.each( Data, function( index, value ){
                          //获取一些数据
                    var Article_Url   = '/index.php/content/' + value.id,
                      Article_Date  = value.date.split(' ')[0];                 
                    
                    //将内容append到列表
                    var Html = '<div class="title"><a href="' + Article_Url + '">' + value.title + '</a></div><div class="desc">' + value.description + '</div><hr>';
                    
                    //在原本的数据列表后面添加新的数据
                    Dom.append( Html );
                    });
                    
                    //设置开关状态为开启,进行下次加载
                    load == true;
                    
                    //页码+1
                    Page += 1;
                    
                } else {
                    
                    //返回数据错误
                    jQuery('#More').html('<span>' + Data + '</span>');
                    
                }
                
            },
            
            error:function( xhr, status, error ){
                        //将内容append到列表
                    var Html = '加载数据错误';
                    
                    //在原本的数据列表后面添加新的数据
                    Dom.append( Html );
            
            }
            
        })
        
    }
    
})
   
    
    
</script>


新闻推荐
龙华网站建设多少钱?
龙华网站建设多少钱?

大家好,这里是黑马视觉,今天我们来聊聊在深圳建一个网站需要多少钱?龙华网站建设需要多少钱?从所周知,...

龙华外贸网站建设必需知道的四大注意事项
龙华外贸网站建设必需知道的四大注意事项

在深圳有很多外贸公司,他们已经不满足于通过其他平台来引流,于是他们都需要建设一个自己自己的外贸网站,...

宝塔防火墙导致无法引入JS
宝塔防火墙导致无法引入JS

在最新一版的宝塔NGINX免费防火墙中,有一条规则是:我们可以看到里面有:script,所以会导致在添加一些第三...

网站没有安装SSL证书了,但是谷歌浏览器依旧跳转到HTTPS,怎么处理?
网站没有安装SSL证书了,但是谷歌浏览器依旧跳转到HTTPS,怎么处...

假如你的网站之前安装了SSL证书,然后到期之后,你将你的网站SSL证书也删除了。但是在使用谷歌浏览器打开网...

Top