Laravel 中獲取上一篇和下一篇數(shù)據(jù)
首先文章的起源來與SF上面的一個(gè)問題:
Laravel的Eloquent ORM 怎么獲取當(dāng)前記錄的下一條
然后,當(dāng)時(shí)在答案里面簡單寫了一下解決方案。不過由于這個(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>
處理文章的前一篇和后一篇的解決方案已完成。
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
- Laravel 5框架學(xué)習(xí)之路由、控制器和視圖簡介
- ThinkPHP、Zend?Framework2、Yaf、Laravel框架路由大比拼
- Laravel 4 初級(jí)教程之視圖、命名空間、路由
- 跟我學(xué)Laravel之路由
- Laravel框架路由配置總結(jié)、設(shè)置技巧大全
- Laravel5.1數(shù)據(jù)庫連接、創(chuàng)建數(shù)據(jù)庫、創(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)文章
Zend?Framework基于Command命令行建立Zend?Framework項(xiàng)目的方法
這篇文章主要介紹了Zend?Framework基于Command命令行建立Zend?Framework項(xiàng)目的方法,較為詳細(xì)的分析了使用Command命令行建立Zend?Framework框架的具體操作步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-02-02
uni-app結(jié)合PHP實(shí)現(xiàn)單用戶登陸demo及解析
這篇文章主要為大家介紹了uni-app結(jié)合PHP實(shí)現(xiàn)單用戶登陸示例過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
一個(gè)PHP實(shí)現(xiàn)的輕量級(jí)簡單爬蟲
這篇文章主要介紹了一個(gè)PHP實(shí)現(xiàn)的輕量級(jí)簡單爬蟲,本文總結(jié)了爬蟲的一些知識(shí)如爬蟲的結(jié)構(gòu)、正則表達(dá)式、其他問題等,然后給出了爬蟲實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-07-07
PHP實(shí)現(xiàn)頁面靜態(tài)化深入講解
這篇文章主要介紹了PHP實(shí)現(xiàn)頁面靜態(tài)化深入講解,本文講解的很透徹,有感興趣的同學(xué)可以研究下2021-03-03
PHP設(shè)計(jì)模式之觀察者模式入門與應(yīng)用案例詳解
這篇文章主要介紹了PHP設(shè)計(jì)模式之觀察者模式入門與應(yīng)用,結(jié)合具體案例形式詳細(xì)分析了PHP觀察者模式的相關(guān)概念、原理、使用方法及操作注意事項(xiàng),需要的朋友可以參考下2019-12-12
PHP中Http協(xié)議post請(qǐng)求參數(shù)
這篇文章主要介紹了Http協(xié)議post請(qǐng)求參數(shù)的相關(guān)資料,需要的朋友可以參考下2015-11-11
CodeIgniter分頁類pagination使用方法示例
這篇文章主要介紹了CodeIgniter分頁類pagination使用方法,結(jié)合實(shí)例形式簡單分析了CodeIgniter框架中的分頁類pagination基本的配置與使用技巧,需要的朋友可以參考下2016-03-03
如何修改Laravel中url()函數(shù)生成URL的根地址
這篇文章主要給大家介紹了關(guān)于如何修改Laravel中url()函數(shù)生成URL根地址的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用laravel具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08

