最近做了简答的文章详情页面,需要在页面底部加入上一篇,下一篇 按钮,分析了下,最基本需要有文章的标题和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, ); | |
视图中
| 代码如下 | 复制代码 |
上一篇: <?=$model['prev_article']['title']?>
下一篇: <?=$model['next_article']['title']?>
| |
Lego Batman Legacy of the Dark Knight的开放世界设计比Arkham系列游戏更出色
蚂蚁庄园2026年3月13日题目答案最新
Turbulent Timeways活动期间获取Spawn of Vyranoth坐骑所需小小魔兽时空漫游周数减少一周
POKI.免费游戏免下载畅玩-POKI.免费游戏全端同步
laravel 实现阿里云oss文件上传功能的示例
删除PHP数组中的重复元素的实现代码