1、

 <div class="pagelist"> <span id="loadmore" class="btn" style="display: block;">加载更多</span> </div>

找到加载更多的按钮,设置好id(最好用id,比较容易遍历)。

2、

<ul id="showajaxnews" style="opacity: 1; top: 0px;">

        [!--empirenews.listtemp--]<!--list.var1-->[!--empirenews.listtemp--]

</ul>

找到列表内容模板的标签,也设置好id。

3、

<script>
$(function () {
var i = 1;
$('#loadmore').click(function () {
$.ajax({
url: '域名/e/action/getmore.php',
type: 'POST',
data: {
"next": i,
'table': 'news',
'classid': '[!--self.classid--]', /*这个标签获取的当前id*/
'action': 'getmorenews',
'limit': 4,
'small_length': 120
},
dataType: 'html',
beforeSend: function () {
$("#loadmore").show().html(
'<img src="/images/loaduai.gif" alt="正在努力加载中...');
$('#loadmore').attr('disabled', 'disabled');
},
success: function (data) {
if (data) {
$("#showajaxnews").append(data);
$("#loadmore").removeAttr('disabled');
$("#loadmore").html('点击加载更多');
i++;
} else {
$("#loadmore").show().html("已全部加载完毕!");
$('#loadmore').attr('disabled', 'disabled');
return false;
}
}
});
});
});
</script>

ajax放到加载更多的下边,记得一定要引入Jquery.

4、

下边标红的,我这里做了一个$classid的判断,意思就是当栏目是父栏目7的时候,调用栏目id 8 和 9 的所有数据。按照自己的情景设置即可。

<?php
require('../class/connect.php');
require('../class/db_sql.php');
require('../data/dbcache/class.php');
if ($_POST[action] == 'getmorenews') {
$table = htmlspecialchars($_POST[table]);
if (empty($_POST[orderby])) {
$orderby = 'newstime';
} else {
$orderby = htmlspecialchars($_POST[orderby]);
}
if (empty($_POST[myorder])) {
$myorder = 'desc';
} else {
$myorder = 'asc';
}
if (empty($_POST[limit])) {
$limit = 6;
} else {
$limit = (int) $_POST[limit];
}
if (empty($_POST[classid])) {
$where = null;
} else if ($_POST[classid] == 7) {
$where = 'where classid in("8,9")';
} else {
$where = 'where classid in(' . $_POST[classid] . ')';
}
if (empty($_POST[length])) {
$length = 50;
} else {
$length = (int) $_POST[length];
}
if (empty($_POST[small_length])) {
$small_length = 500;
} else {
$small_length = (int) $_POST[small_length];
} // next:第几页
// table:调用数据表
// limit:每次调用数量
// small_length:简介截取字符数
// length:标题截取字符数
// classid:调用栏目,允许多个,如1,2,3,4 特别注意,必须是调用同一数据表的栏目
// orderby:排序,默认是newstime,传什么就按什么来排序,如 id
// myorder:正反序,默认是asc,传值怎为desc $link = db_connect();
$empire = new mysqlquery();
$num = (int) $_POST['next'] * $limit; if ($table) {
$sql = $empire->query("SELECT * FROM `" . $dbtbpre . "ecms_" . $table . "` $where order by $orderby $myorder limit $num,$limit"); while ($r = $empire->fetch($sql)) { if ($r[mtitlepic] == '') {
$r[mtitlepic] = $public_r[news . url] . "e/data/images/notimg.gif";
}
$oldtitle = stripSlashes($r[title]);
$title = sub($oldtitle, '', $length);
$smalltext = stripSlashes($r[smalltext]);
$smalltext = sub($smalltext, '', $small_length);
$classname = $class_r[$r[classid]][classname];
$newsurl = $public_r[newsurl];
$classurl = $newsurl . $class_r[$r[classid]][classpath];
$urls = sys_ReturnBqTitleLink($r); ?>
<!-- 以下代码是显示列表的标签模板 ,按照情景修改即可。-->
<li>
<a href="<?= $urls ?>">
<div class="img">
<img src="<?= $r[titlepic] ?>" class="lazy"></div>
<div class="con">
<h2>
<?= $r[title] ?>
</h2>
<p>
<?= $r[smalltext] ?>
</p>
<span>
<?= date("Y-m-d", $r[newstime]) ?>
</span>
</div>
<div class="more">
<span></span>
</div>
</a>
</li>
<?php
}
}
}
db_close();
$empire = null;
?>

建立一个getmore.php文件,把上边代码上传到/e/action/文件中

帝国cms 加载更多的实现(父栏目以及子栏目都可以实现)的更多相关文章

  1. 关于Vue中页面(父组件)下拉,页面中的子组件加载更多数据的实现方法

    一个项目中存在很多这种情况:父组件(页面)中的子组件需要做下拉加载更多的需求,但是这个下拉到底部的动作只能通过监控页面(父组件)来完成 这就需要父子组件之间的通信,代码如下: 1. 建立一个用于父子组 ...

  2. mui的上拉加载更多 下拉刷新 自己封装的demo

    ----------------------------------------------- 这是一个非常呆萌的程序妹子,深夜码的丑代码------------------------------- ...

  3. 基于 Vue.js 的移动端组件库mint-ui实现无限滚动加载更多

    通过多次爬坑,发现了这些监听滚动来加载更多的组件的共同点, 因为这些加载更多的方法是绑定在需要加载更多的内容的元素上的, 所以是进入页面则直接触发一次,当监听到滚动事件之后,继续加载更多, 所以对于无 ...

  4. 使用vue之directive设计列表加载更多

    背景 之前写过一篇<纯JS实现加载更多(VUE框架)>,它的逻辑思路比较清晰易懂,而今天看了一天公司项目的部分功能代码,发现同事们写的加载更多的功能更加的有趣,而且易于封装到一个组件当中, ...

  5. 纯JS实现加载更多(VUE框架)

    <template> <div class = 'car_list' reft='scrollobx' @scroll='scrollready($event)'> </ ...

  6. react-native ListView 封装 实现 下拉刷新/上拉加载更多

    1.PageListView 组件封装 src/components/PageListView/index.js /** * 上拉刷新/下拉加载更多 组件 */ import React, { Com ...

  7. vue2.0 自定义 下拉刷新和上拉加载更多(Scroller) 组件

    1.下拉刷新和上拉加载更多组件 Scroller.vue <!-- 下拉刷新 上拉加载更多 组件 --> <template> <div :style="mar ...

  8. Android 实现下拉刷新和上拉加载更多的RECYCLERVIEW和SCROLLVIEW

    PullRefreshRecyclerView.java /** * 类说明:下拉刷新上拉加载更多的RecyclerView * Author: gaobaiq * Date: 2016/5/9 18 ...

  9. mui实现分页上拉加载更多 下拉刷新数据的简单实现 移动端下拉上拉

    空下来把mui上拉加载更多,下拉刷新数据做了一个简单的实现,希望可以帮助到需要的朋友 demo项目的结构 <!DOCTYPE html> <html> <head> ...

随机推荐

  1. 前端知识点回顾之重点篇——CORS

    CORS(cross origin resource sharing)跨域资源共享 来源:http://www.ruanyifeng.com/blog/2016/04/cors.html 它允许浏览器 ...

  2. spring boot 全局异常处理及自定义异常类

    全局异常处理: 在处理controller层抛出的自定义异常时,可以实现@ControllerAdvice注解捕获,配合@ExceptionHandler来增强所有的@requestMapping方法 ...

  3. leetcode1283 使结果不超过阈值的最小除数

    这道题第一思路是用二分查找 因为使用二分法:所以复杂度为O(n*logk), k介于 left=sum/threshold(向下取整) 和 right=num_max之间:而right<=10^ ...

  4. python之scrapy模块scrapy-redis使用

    1.redis的使用,自己可以多学习下,个人也是在学习 https://www.cnblogs.com/ywjfx/p/10262662.html官网可以自己搜索下. 2.下载安装scrapy-red ...

  5. idea设置背景色和字体大小

    修改背景色  点击[File],选择[Settings]. 点击[Editor],选择[color Scheme]. 默认Scheme只有两种.Default是白色,Darcula是黑色   修改字体 ...

  6. AP注册

    1.ac发现ap 两种模式:二层发现.三层发现 按ap与ac所处ip网段不同,可以把注册过程分为二层模式和三层模式: 两种模式均通过发送discovery报文进行,二层模式discovery报文仅在同 ...

  7. 【CodeForces - 707B】Bakery(思维水题)

    Bakery Descriptions 玛莎想在从1到n的n个城市中开一家自己的面包店,在其中一个城市烘焙松饼. 为了在她的面包房烘焙松饼,玛莎需要从一些储存的地方建立面粉供应.只有k个仓库,位于不同 ...

  8. C# MVC MVP

    https://www.codeproject.com/Articles/613682/Your-first-program-using-MVC-pattern-with-Csharp-W https ...

  9. day24 类的初始化、绑定方法、继承

    今日内容 1.初始化函数 2.绑定方法与非绑定方法 3.绑定方法的特殊之处 4.类的继承 一.初始化函数 1.什么是初始化函数 我们在使用类创建对象时,创建出来的对象都会拥有类中的属性和方法,但是每个 ...

  10. SGI STL内存管理

    前言 万丈高楼平地起,内存管理在C++领域里扮演着举足轻重的作用.对于SGI STL这么重量级的作品,当然少不了内存管理的实现.同时,想要从深层次理解SGI STL的原理,必须先将内存管理这部分的内容 ...