最近做了简答的文章详情页面,需要在页面底部加入上一篇,下一篇 按钮,分析了下,最基本需要有文章的标题和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 :'没有了',
- ]; //Vevb.com
- return$this->render('view',
- 'model'=>$model,
- );
视图中代码如下:
- <divclass="left">
- <p>上一篇:
- <a href="<?=$model['prev_article']['url']?>">
- <?=$model['prev_article']['title']?>
- </a>
- </p>
- </div>
- <divclass="right">
- <p>下一篇:
- <a href="<?=$model['next_article']['url']?>">
- <?=$model['next_article']['title']?>
- </a>
- </p>
- </div>
新闻热点
疑难解答