yii2實現 "上一篇,下一篇" 功能的代碼實例
更新時間:2017年02月04日 11:33:23 作者:hebo5485
在很多頁面上都需要加入上一篇,下一篇 按鈕,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
最近做了簡答的文章詳情頁面,需要在頁面底部加入上一篇,下一篇 按鈕,分析了下,最基本需要有文章的標題和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>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Windows7下PHP開發(fā)環(huán)境安裝配置圖文方法
備花點時間學習下PHP,于是在自己機器上配置了下PHP的開發(fā)和運行環(huán)境。之前在Windows Server 2003 OS中手工配置過,WEB服務器是IIS。這次是在自己機器上配置,找了個簡單方式。2010-05-05

