帝国cms 加载更多的实现(父栏目以及子栏目都可以实现)
时间:2024年02月10日
/来源:网络
/编辑:佚名
帝国cms加载更多的实现(父栏目以及子栏目都可以实现)方法
第一步:
<div class="pagelist"> <span id="loadmore" class="btn" style="display: block;">加载更多</span> </div>
找到加载更多的按钮,设置好id(最好用id,比较容易遍历)。
第二步:
<ul id="showajaxnews" style="opacity: 1; top: 0px;">
[!--empirenews.listtemp--]<!--list.var1-->[!--empirenews.listtemp--]
</ul>
找到列表内容模板的标签,也设置好id。
第三步:
复制代码
<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/文件中。
第一步:
<div class="pagelist"> <span id="loadmore" class="btn" style="display: block;">加载更多</span> </div>
找到加载更多的按钮,设置好id(最好用id,比较容易遍历)。
第二步:
<ul id="showajaxnews" style="opacity: 1; top: 0px;">
[!--empirenews.listtemp--]<!--list.var1-->[!--empirenews.listtemp--]
</ul>
找到列表内容模板的标签,也设置好id。
第三步:
复制代码
<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教程】帝国CMS模板变量$GLOBALS[navclassid]用法分析04-03
- 【帝国cms教程】鲜为人知帝国CMS内容页调用上一篇和下一篇的精华方法汇总04-03
- 【帝国cms教程】怎么快速找出帝国CMS数据库配置文件路径及迁移网站后修改技巧!04-03
- 【帝国cms教程】帝国CMS模板$GLOBALS[navclassid]用法详解04-03
- 【帝国cms教程】帝国cms 7.5版列表页分页样式修改笔记04-02
- 【帝国cms教程】解决帝国CMS搜索页面模板不支持灵动标签和万能标签的方法04-02
- 【帝国cms教程】帝国CMS只备份栏目和模板的方法04-02
- 【帝国cms教程】帝国CMS怎样删除清空数据库记录?04-02
热门文章
- 178Moban源码谈谈免费源码与收费源码的区别
- 2帝国CMS忘记后台登陆用户名、密码、认证码的解决方法
- 3帝国CMS(EmpireCMS) v7.5后台任意代码执行漏洞及具体修复方法
- 4帝国CMS和WordPress 哪个好?哪个适合建站?
- 5如何解决Discuz的密码错误次数过多请15分钟后登陆的问题
- 6帝国cms灵动标签取得内容和栏目链接地址
- 7emlog pro 注册码“开心”教程(如果有一天,emlog官方版 或者 emlog免费版 跑路了,那用户怎么办?)
- 8织梦CMS在nginx下设置伪静态方法(附nginx伪静态规则)
- 9帝国cms后台登录出现”您还未登录”怎么解决?
- 10帝国cms7.5忘记登录密码 和忘记登录认证码以及多次登录 失败被锁定解决办法