请先登录

实现yii2 上一篇 下一篇功能.

作者:         标签: yii2  PHP  技术            发布时间:2017-09-27 11:44:15          0

最近做了简答的文章详情页面,需要在页面底部加入上一篇,下一篇 按钮,分析了下,最基本需要有文章的标题和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, 
   );

评论
  • 1楼           2017-09-28 17:02:43


    额,呵呵哒

  • 回复
  • 2楼           2017-09-28 17:15:13


    哈哈啥

  • 回复
  • 3楼           2017-09-28 17:34:16


    树新风


  •   评论于  2017-09-28 17:34:31

    你知道个屁


      评论于  2017-09-28 17:34:40

    你也是盒盒


    回复
  • 4楼           2017-09-28 17:39:13


    上大大的

    <?php 
    echo "hello world";
    ?>
    

  •   评论于  2017-09-28 17:46:59

    quba


    回复

输入评论内容