Laravel 中獲取上一篇和下一篇數(shù)據(jù)
首先文章的起源來與SF上面的一個(gè)問題:
Laravel的Eloquent ORM 怎么獲取當(dāng)前記錄的下一條
然后,當(dāng)時(shí)在答案里面簡(jiǎn)單寫了一下解決方案。不過由于這個(gè)取得下一條和取得上一條的記錄其實(shí)在日常的開發(fā)當(dāng)中還是會(huì)經(jīng)常遇到,最常見的場(chǎng)景可能就是取得一篇文章的上一篇文章和下一篇文章了。其實(shí)這個(gè)在Laravel的Eloquent中實(shí)現(xiàn)還是挺容易的,不過由于Laravel并沒有直接提供給我們相應(yīng)的方法,我們得使用一個(gè)小小的技巧:
取得上一篇的文章id
protected function getPrevArticleId($id) { return Article::where('id', '<', $id)->max('id'); }
$id就是當(dāng)前文章的id,我們通過max()來取得比當(dāng)前id小的最大值,也就是當(dāng)前id的前一篇文章的id。
取得上一篇的文章id
protected function getNextArticleId($id) { return Article::where('id', '>', $id)->min('id'); }
基本上可以說是:同理可得。這個(gè)取得下一篇文章的id其實(shí)就是一個(gè)相反的過程,理解萬歲。
一旦我們?nèi)〉蒙弦黄拖乱黄奈恼耰d之后,我們就可以隨心所欲了,比如:
多說兩句
那如果是對(duì)于一個(gè)文章的管理來說,我們其實(shí)可以這么做:
給articles表中增加一個(gè)published_at的字段,這里可以將published_at字段設(shè)置為一個(gè)Carbon對(duì)象,然后我們?cè)谇岸苏故镜臅r(shí)候就可以根據(jù)published_at來判讀是否將文章展示出來。
比如說查詢語句:
public function scopePublished($query) { $query->where('published_at','<=',Carbon::now()); }
//以上方法位于Article中,下面的查詢我放在了ArticleController中
$articles = Article::latest('published_at')->published()...
View展示:
<li class="previous"> @if($prev_article) <a href="/post/{{ $prev_article->slug }}" rel="prev"><i class="fa fa-chevron-left"></i><strong>上一篇</strong><span> {{ $prev_article->title }}</span> </a> @endif </li> <li class="next"> @if($next_article && $next_article->published_at < Carbon\Carbon::now()) <a href="/post/{{ $next_article->slug }}" rel="next"><i class="fa fa-chevron-right"></i><strong>下一篇</strong> <span> {{ $next_article->title }}</span></a> @endif </li>
處理文章的前一篇和后一篇的解決方案已完成。
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
- Laravel 5框架學(xué)習(xí)之路由、控制器和視圖簡(jiǎn)介
- ThinkPHP、Zend?Framework2、Yaf、Laravel框架路由大比拼
- Laravel 4 初級(jí)教程之視圖、命名空間、路由
- 跟我學(xué)Laravel之路由
- Laravel框架路由配置總結(jié)、設(shè)置技巧大全
- Laravel5.1數(shù)據(jù)庫(kù)連接、創(chuàng)建數(shù)據(jù)庫(kù)、創(chuàng)建model及創(chuàng)建控制器的方法
- Laravel中Trait的用法實(shí)例詳解
- Laravel實(shí)現(xiàn)構(gòu)造函數(shù)自動(dòng)依賴注入的方法
- 基于laravel制作APP接口(API)
- PHP框架Laravel學(xué)習(xí)心得體會(huì)
- Laravel路由設(shè)定和子路由設(shè)定實(shí)例分析
相關(guān)文章
Yii框架參數(shù)配置文件params用法實(shí)例分析
這篇文章主要介紹了Yii框架參數(shù)配置文件params用法,結(jié)合實(shí)例形式分析了Yii框架參數(shù)配置文件params相關(guān)設(shè)置、調(diào)用、加載等操作技巧與注意事項(xiàng),需要的朋友可以參考下2019-09-09Yii實(shí)現(xiàn)MySQL多數(shù)據(jù)庫(kù)和讀寫分離實(shí)例分析
這篇文章主要介紹了Yii實(shí)現(xiàn)MySQL多數(shù)據(jù)庫(kù)和讀寫分離的方法,以實(shí)例形式詳細(xì)的分析了Yii數(shù)據(jù)庫(kù)讀寫分離的方法,是開發(fā)大型項(xiàng)目非常實(shí)用的技巧,需要的朋友可以參考下2014-12-12php使用mkdir創(chuàng)建多級(jí)目錄入門例子
這篇文章主要介紹了php使用mkdir創(chuàng)建多級(jí)目錄入門例子,需要的朋友可以參考下2014-05-05php實(shí)現(xiàn)memcache緩存示例講解
共享內(nèi)存是一種在相同機(jī)器中的應(yīng)用程序之間交換數(shù)據(jù)的有效方式,本文說的是php實(shí)現(xiàn)memcache緩存示例,大家參考使用吧2013-12-12ThinkPHP中url隱藏入口文件后接收alipay傳值的方法
這篇文章主要介紹了ThinkPHP中url隱藏入口文件后接收alipay傳值的方法,可實(shí)現(xiàn)針對(duì)第三方接口的URL地址中的?進(jìn)行轉(zhuǎn)換處理,是非常實(shí)用的技巧,需要的朋友可以參考下2014-12-12用Php編寫注冊(cè)后Email激活驗(yàn)證的實(shí)例代碼
通過使用Email驗(yàn)證激活的方法,可以有效的幫你阻止惡意的Spam和注冊(cè)機(jī)器人的訪問。 用php編寫注冊(cè)后Email驗(yàn)證激活的步驟非常簡(jiǎn)單,相信幾分鐘之內(nèi)你就能學(xué)會(huì)。2013-03-03php根據(jù)數(shù)據(jù)id自動(dòng)生成編號(hào)的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猵hp根據(jù)數(shù)據(jù)id自動(dòng)生成編號(hào)的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10