tp5上一篇下一篇;php上一篇下一篇

最终实现效果:

tp5上一篇下一篇;php上一篇下一篇_第1张图片

前提:文章有分类,权重,时间排序等

流程:因为这个功能不算难,本来想着是否能伸手主义一次,直接去网上拷贝一下直接用,奈何百度一下发现很多都是直接用的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);

前台输出:


文章由优倍素材网:https://www.51sucai.com.cn 整理,转发请注明出处。

你可能感兴趣的:(thinkphp5开发总结,php开发过程中踩过的坑)