yii2實現(xiàn) "上一篇,下一篇" 功能的代碼實例
更新時間:2017年02月04日 11:33:23 作者:hebo5485
在很多頁面上都需要加入上一篇,下一篇 按鈕,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
最近做了簡答的文章詳情頁面,需要在頁面底部加入上一篇,下一篇 按鈕,分析了下,最基本需要有文章的標(biāo)題和id(作為參數(shù)).
開始想的是當(dāng)前的id加減1,但考慮到如果部分id丟失就不對了,于是分別查詢比當(dāng)前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>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
php+iframe實現(xiàn)隱藏?zé)o刷新上傳文件
首先ajax不能上傳文件,這誤導(dǎo)了我有段時間,今晚睡不著就照著說明做了個無刷新上傳文件2012-02-02Windows7下PHP開發(fā)環(huán)境安裝配置圖文方法
備花點時間學(xué)習(xí)下PHP,于是在自己機(jī)器上配置了下PHP的開發(fā)和運(yùn)行環(huán)境。之前在Windows Server 2003 OS中手工配置過,WEB服務(wù)器是IIS。這次是在自己機(jī)器上配置,找了個簡單方式。2010-05-05