yii2 实现 "上一篇,下一篇" 功能 [ 2.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,
);
视图中
<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>
hebo5485
注册时间:2016-03-18
最后登录:2024-04-05
在线时长:66小时28分
最后登录:2024-04-05
在线时长:66小时28分
- 粉丝8
- 金钱4600
- 威望30
- 积分5560
共 5 条评论
思路正确的
使用yii2自带的分页就可以实现上一篇、下一篇。不用这么麻烦。
视图
<?php echo LinkPager::widget([ 'pagination' => $pager, 'prevPageLabel' => '上一篇', 'nextPageLabel' => '下一篇', 'maxButtonCount' => 0, ]); ?> 控制器
$pager = new Pagination(['totalCount' => $count, 'pageSize' =>1]);
好像不错的样子,O(∩_∩)O
你说的是分页,而我说的不是这个哦
效果如下:
如果加了其他排序字段呢?而不是单单根据ID升序或降序来排序。SQL语句应该怎么写?
原文地址:http://skyline-traveler.com/blog/post/item?id=21