搜索
系统检测到您的用户名不符合规范:

通过调用数据库得到的上一页下一页的id

浏览:1956 发布日期:2015年07月21日 分类:功能实现 关键字: 导航
这个功能在文章页面中实现‘上一页’,‘下一页’导航链接时需要用到,但是文章的id一般是不连贯的,所以不能通过当前页id加一减一实现,而是查询数据库上下两行的记录的id来实现,现在写成函数如下
<?php
function article_guide($current_id,$table_name){//$current_id一般通过get得到
$A = M($table_name);//A = article
$result = $A->order('id ASC')->select();
$guide['min_id'] = $link[0]['id']; //数据库中最小的id
$guide['max_id'] = $link[count($result)-1]['id']; //数据库中最大的id
//得到上一篇文章的ID
$prev_id = $current_id-1;
while(($A->where('id="'.$prev_id.'"')->getField('id')) == false){
if($prev_id <= $min_id){
$prev_id = '-1';//表示已经是最早的文章
break ;
}
$prev_id--;
}
//得到下一篇文章的id
$next_id = $current_id+1;
while(($A->where('id="'.$next_id.'"')->getField('id')) == false){
if($next_id >= $max_id) {
$next_id = '-2';//表示已经是最新的文章
break;
}
$next_id++;
}
$guide['next_id'] = $next_id;
$guide['prev_id'] = $prev_id;
return $guide;
}
在你需要使用的操作中调用此函数,然后给模板赋值,给相应的上一页下一页链接添加相应的id即可。
还可以通过id判断页面是否可以访问:I('get.id') == -1 ? $this->error('没有更早的文章了!','index') : false;
I('get.id') == -2 ? $this->error('没有更新的文章了!','index') : false;
评论() 相关
后面还有条评论,
评论支持使用[code][/code]标签添加代码
您需要登录后才可以评论 登录 | 立即注册
收藏
MartiaHiblite
积分:591 等级:LV2
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。

AltStyle によって変換されたページ (->オリジナル) /