搜索
当前所在位置: 首页>网站问题

pbootcms使用api接口实现Ajax无刷新加载更多文章

发布时间:2023-12-03 01:11:38 作者:超级管理员 点击:70 【 字体:

实现方法

pbootcms自带了API接口,我们可以通过这个API接口http://IP/api.php/list/ 调取分页所需的数据。

我建议这种分页,不要一上来就全部使用Ajax获取数据,因为Ajax是不会被百度收录的。

我建议的做法是,在列表页先使用模板标签输出一些数据。例如:

<div class="newslist">
    <ul>
    {pboot:list num=6}
    <li>
        <a href="[list:link]">[list:title]</a>
    </li>
    {/pboot:list}
    </ul>
    <a href="javascript:;" class="loadmore">加载更多</a>
</div>

先读取6条数据,让搜索引擎最少能抓取到最新的6条文章。

然后再使用Ajax去调取剩余的新闻内容,实现点击加载更多的效果。

下面就是核心AJAX调取API数据部分代码

<script>
    $(function(){
        var Page = 1;
        // 每页展示12个
        var Num = 6;
        $(document).on('click','.loadmore',function(){
            // 页数
            Page++;
            $.ajax({
                type: 'POST',
                url: '/api.php/list/{sort:scode}/page/' + Page + '/num/' + Num + '/order/sorting',
                dataType: 'json',
                data: {
                    appid: '{pboot:appid}',
                    timestamp: '{pboot:timestamp}',
                    signature: '{pboot:signature}',
                },
                success: function( response, status ){
                    console.log(response);
                    var Data = response.data;
                    if( response.code ){
                        //获取数据成功
                        var Html = '';
                        jQuery.each( Data, function( index, value ){
                            //构建HTML
                            Html +=  '<li>';
                            Html +=  '    <a href="'+ value.contentlink +'">'+ value.title +'</a>';
                            Html +=  '</li>';
                        });
                        // 为了测试,延迟1秒加载
                        setTimeout(function(){
                            // 插入数据到页面,放到最后面
                            $('.newslist ul').append(Html);
                        },500);
                    }else{
                        $('.loadmore').slideUp();
                    }
                },
                error: function(xhr, type){
                    console.log('Ajax error!');
                }
            });
        });
    });
</script>

简单解释一下这个代码,从第二页开始读取,每次读取6条。为什么从第二页开始读取?因为前面我们已经在模板里输出6条数据啦。


注意事项

请注意在后台开启WebAPI,如下图。


其中API强制认证,可以按你的实际情况选择启用。


阅读全文
相关推荐

pbootcmsV3.2.5版本怎么设置网站缓存一天更新一次?

pbootcmsV3.2.5版本怎么设置网站缓存一天更新一次?
pbootcmsV3.2.5版本的网站有些数据需要经常更新,至少一天更新一次。我们设置缓存有效期为86400秒即可。...

织梦后台文档列表无法找到404错误问题

织梦后台文档列表无法找到404错误问题
问题描述客户反应织梦后台文档列表突然打不开,提示404错误页面,之前一直正常。其他菜单一切正常,唯独文档列表打不开。解决思路检查文档列表页面content_list.php文件也都正常,排除文件被误删情况。第一反应是不是网站被黑了,经过一系列排查后发现网站并没有被黑。那么就应该是主机设置或者是程序参数设置有问题。登录宝...

pbootcms模板常用php代码 可直接写在模板中

pbootcms模板常用php代码 可直接写在模板中
自用备忘 不做介绍<?php//获取一条定制标签名称为comtype的值,并用|分割循环输出常用于多个微信号码/多个电话等的输出$list=\core\basic\Db::table('ay_label')->field('value')->where("name='comtype'")->find();$list=explode('...

pbootcms网站后台突然登录不了啦

pbootcms网站后台突然登录不了啦
使用pbootcms程序做的网站,后台账号和密码都没有错误,今天突然登录不了。如果您使用的是pbootcmsV3.2.5以前的版本,请删除runtime文件后重新登陆尝试,一般是缓存文件太多,主机商给限制了,我们只需要删除这个文件夹即可。如果删除后依然登录不了,可能是网站被黑了。...

pbootcms栏目外链时在新建标签页打开target="_blank"

pbootcms栏目外链时在新建标签页打开target=
需求描述客户的网站导航菜单需要添加几个外链,因非本站链接,所以需要在新窗口打开。pboot:nav代码{pboot:navparent=0}<ahref="[nav:link]"{pboot:if('[nav:outlink]'!='')}target="_blank"{/pboot:if}>[nav:name]</a>{/pboot:nav}...

工作插画素材设计,程序员动态表情包下载

工作插画素材设计,程序员动态表情包下载
这是一款工作插画素材设计,程序员动态表情包下载,画面中呈现了程序员工作的动画效果,循环自动播放,可用于网页插图。...

pbootcms新版发布后要不要立即进行升级?

pbootcms新版发布后要不要立即进行升级?
我经常建议大家经常关注pbootcms官方新版程序发布,对自己的网站程序及时进行升级更新。这里我做下更正,建议大家在新版发布一周后再进行升级。这期间如果新版有什么问题,也会有别的技术反馈给官方,官方进行修复后再二次发布。所以建议大家在官方发布一周后在进行升级处理。...

pbootcms安装后页面空白网站后台也登录不了

pbootcms安装后页面空白网站后台也登录不了
新搬家的网站或者是刚升级版本的网站数据库连接配置文件都没有问题但是一直登录不了后台。前台页面一片空白。有两种可能1,php版本太低,切换php7.0以上的版本试试。2,使用mysql数据库的很大可能是mysql数据库导入不完整,检查数据表是不是完整。...

变现新途径!视频号“创作分成计划”上线 评论区广告来了

变现新途径!视频号“创作分成计划”上线 评论区广告来了
日前,视频号宣布“创作分成计划”上线,通过评论区广告助力创作者获得收益,再添变现途径。据悉,视频号创作分成计划是基于视频号生态体系,符合一定条件的视频号优质原创作者,可在原创视频评论区通过展示广告内容,获取广告收入的模式。优质原创作者发表视频内容并声明原创,该视频的评论区则有机会向用户智能展示最适合...

日历界面布局设计,时间日历桌面模板

日历界面布局设计,时间日历桌面模板
这是一款日历界面布局设计,时间日历桌面模板,该模板包含日历、星期、时间插件,界面简约大气,100%响应,希望大家能够喜欢。...
返回顶部