hebo5485 2017-01-13 15:51:09 6480次浏览 5条评论 15 2 1

最近做了简答的文章详情页面,需要在页面底部加入上一篇,下一篇 按钮,分析了下,最基本需要有文章的标题和id(作为参数).

开始想的是当前的id加减1,但考虑到如果部分id丢失就不对了,于是分别查询比当前id大和小的记录并且限定为一条,于是有了以下代码
代码如下,不对的地方请指教.


控制器中

//查询上-篇文章
        $prev_article = 你的模型::find()
            ->andFilterWhere(['<', 'id', $id])
            ->andFilterWhere([其他条件)
            ->orderBy(['id' => SORT_DESC])
            ->limit(1)
            ->one();
        //查询下-篇文章
        $next_article = 你的模型::find()
            ->andFilterWhere(['>', 'id', $id])
            ->andFilterWhere(其他条件)
            ->orderBy(['id' => SORT_ASC])
            ->limit(1)
            ->one();


        $model['prev_article'] = [
            'url' => !is_null($prev_article) ? Url::current(['id'=>$prev_article->id]) : 'javascript:;',
            'title' => !is_null($prev_article) ? $prev_article->title : '没有了',
        ];

        $model['next_article'] = [
            'url' => !is_null($next_article) ? Url::current(['id'=>$next_article->id]) : 'javascript:;',
            'title' => !is_null($next_article) ? $next_article->title : '没有了',
        ];

        return $this->render('view', 
            'model' => $model, 
       );

视图中

<div class="left">
        <p>上一篇:
            <a href="<?=$model['prev_article']['url']?>">
                <?=$model['prev_article']['title']?>
            </a>
        </p>
    </div>
    <div class="right">
        <p>下一篇:
            <a href="<?=$model['next_article']['url']?>">
                <?=$model['next_article']['title']?>
            </a>
        </p>
    </div>
觉得很赞
您需要登录后才可以评论。登录 | 立即注册