- 155浏览
- 2022-05-08
流程:因为这个功能不算难,本来想着是否能伸手主义一次,直接去网上拷贝一下直接用,奈何百度一下发现很多都是直接用的id为参照,比当前id小的即为上一篇,反之则为下一篇,这样的话弊端就相当明显,如果在列表中加上分类,权重排序,时间排序等等,显而易见简单的根据id取值就有些误差,故重新整理一份,不仅tp5适用,其他程序也可以用,此处仅以tp5做说明
上代码:
$art_id = Request::instance()->param('art_id');
$detail_info = Db::name("article")->where("id",$art_id)->find();
//更新文章阅读次数
$update_read_num = [
'read_num' => $detail_info['read_num']+1,
];
Db::name("article")->where("id",$art_id)->update($update_read_num);
//查找上一篇下一篇
/*
查找出全部id,组合一个数组,根据索引去判断上一个或下一个是否存在
*/
$where['lm'] = $detail_info['lm']; //查询条件之所属栏目
$where['pass'] = 'yes'; //查询条件之是否显示
$all_id = Db::name("article")->field('id')->where($where)->order('px desc,create_time')->select();
$id_array = array();
foreach ($all_id as $key => $value) {
if($value['id'] == $art_id){
//定位当前
//获取下一篇
if(isset($all_id[$key+1])){
$next_id = $all_id[$key+1]['id'];
}else{
$next_id = '';
}
//获取上一篇
if(isset($all_id[$key-1])){
$pre_id = $all_id[$key-1]['id'];
}else{
$pre_id = '';
}
}
}
if($next_id != ''){
$next_info = Db::name("article")->field('id,article_name')->where("id",$next_id)->find();
}else{
$next_info = '';
}
if($pre_id != ''){
$pre_info = Db::name("article")->field('id,article_name')->where("id",$pre_id)->find();
}else{
$pre_info = '';
}
$this->assign("next_info",$next_info);
$this->assign("pre_info",$pre_info);
前台输出:
<div class="share">
<div class="share-bg">
<div class="share-href pull-left text-left">
{if condition="$pre_info != ''"}
<a href="{:url('home/index/news_show',['art_id'=>$pre_info.id])}">上一篇:{$pre_info.article_name}</a>
{else /}
<a href="#">上一篇:没有了</a>
{/if}
{if condition="$next_info != ''"}
<a href="{:url('home/index/news_show',['art_id'=>$next_info.id])}">上一篇:{$next_info.article_name}</a>
{else /}
<a href="#">下一篇:没有了</a>
{/if}
</div>
<div class="text-right share-r pull-right"><a href="{:url('home/index/news',['art_type'=>$art_type_name.id])}">返回</a></div>
</div>
</div>
版权声明:
1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。
2、本站仅提供信息发布平台,不承担相关法律责任。
3、若侵犯您的版权或隐私,请联系本站管理员删除。
4、本文由会员转载自互联网,如果您是文章原创作者,请联系本站注明您的版权信息。