国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
Laravel 自帶的分頁類別
自訂視圖
自訂樣式
總結(jié)
首頁 php框架 Laravel laravel怎麼實(shí)現(xiàn)自訂樣式的分頁功能

laravel怎麼實(shí)現(xiàn)自訂樣式的分頁功能

Apr 11, 2023 pm 03:06 PM

隨著 Laravel 框架的不斷發(fā)展,現(xiàn)在越來越多的 Web 專案都選擇了它,當(dāng)然也有很多開發(fā)者選擇使用 Laravel 開發(fā)自己的網(wǎng)站。在日常開發(fā)中,對(duì)於實(shí)現(xiàn)功能的實(shí)現(xiàn),通常的做法是先尋找開源的庫或自己寫組件,互聯(lián)網(wǎng)上有很多前人的經(jīng)驗(yàn)與總結(jié),本篇文章就是其中之一,它會(huì)告訴你如何使用Laravel 自帶的分頁類別來實(shí)現(xiàn)自訂樣式的分頁。

Laravel 自帶的分頁類別

Laravel 框架自帶了分頁庫,使用起來非常方便。在控制器中我們一般使用paginate() 方法來查詢資料並返回分頁結(jié)果,而在Blade 模板中我們可以直接使用links() 方法來渲染分頁鏈接,看下面的程式碼:

//?在控制器中查詢數(shù)據(jù)并返回分頁結(jié)果
$data?=?DB::table('table_name')->paginate(15);

//?在?Blade?模板中通過?links()?方法渲染分頁鏈接
{{?$data->links()?}}

這樣程式碼就完成了分頁查詢的工作,並且將分頁連結(jié)渲染到了頁面上。但是這樣的連結(jié)樣式是預(yù)設(shè)的,如果想要更改樣式,我們需要自訂視圖。

自訂視圖

我們先來了解下links() 方法,我們可以在Blade 範(fàn)本中輸出一下{{ $data->links () }} 的值,得到的結(jié)果是這樣的:

<ul class="pagination">
????<li class="page-item disabled" aria-disabled="true" aria-label="&laquo; Previous">
????????<span class="page-link" aria-hidden="true">&lsaquo;</span>
????</li>
????<li class="page-item active" aria-current="page"><span class="page-link">1</span></li>
????<li class="page-item"><a class="page-link" href="http://localhost?page=2">2</a></li>
????<li class="page-item"><a class="page-link" href="http://localhost?page=3">3</a></li>
????<li class="page-item"><a class="page-link" href="http://localhost?page=4">4</a></li>
????<li class="page-item"><a class="page-link" href="http://localhost?page=5">5</a></li>
????<li class="page-item">
????????<a class="page-link" href="http://localhost?page=2" rel="next" aria-label="Next &raquo;">&rsaquo;</a>
????</li>
</ul>

我們發(fā)現(xiàn),links() 方法預(yù)設(shè)渲染的分頁連結(jié)是一個(gè)無序列表,每一項(xiàng)目都是一個(gè)獨(dú)立的li 元素,其中active 類別表示目前頁碼,disabled 類別表示不可用的頁碼。如果我們想要自訂分頁連結(jié)的樣式,就需要在視圖檔案中覆寫 Laravel 預(yù)設(shè)的連結(jié)渲染。

在Laravel 中,可以使用php artisan make:view 指令來產(chǎn)生視圖文件,如下:

php?artisan?make:view?pagination

這個(gè)指令將在resources/views 目錄下建立一個(gè)名為pagination.blade.php 的檔案。在該文件中寫入如下程式碼:

@if?($paginator->hasPages())
????<nav>
????????<ul class="pagination">
????????????{{--?Previous?Page?Link?--}}
????????????@if?($paginator->onFirstPage())
????????????????<li class="page-item disabled" aria-disabled="true" aria-label="@lang(&#39;pagination.previous&#39;)">
????????????????????<span class="page-link" aria-hidden="true">&lsaquo;</span>
????????????????</li>
????????????@else
????????????????<li class="page-item">
????????????????????<a class="page-link" href="{{ $paginator->previousPageUrl()?}}"?rel="prev"?aria-label="@lang('pagination.previous')">&lsaquo;</a>
????????????????</li>
????????????@endif

????????????{{--?Pagination?Elements?--}}
????????????@foreach?($elements?as?$element)
????????????????{{--?"Three?Dots"?Separator?--}}
????????????????@if?(is_string($element))
????????????????????<li class="page-item disabled" aria-disabled="true"><span class="page-link">{{?$element?}}</span></li>
????????????????@endif

????????????????{{--?Array?Of?Links?--}}
????????????????@if?(is_array($element))
????????????????????@foreach?($element?as?$page?=>?$url)
????????????????????????@if?($page?==?$paginator->currentPage())
????????????????????????????<li class="page-item active" aria-current="page"><span class="page-link">{{?$page?}}</span></li>
????????????????????????@else
????????????????????????????<li class="page-item"><a class="page-link" href="{{ $url }}">{{?$page?}}</a></li>
????????????????????????@endif
????????????????????@endforeach
????????????????@endif
????????????@endforeach

????????????{{--?Next?Page?Link?--}}
????????????@if?($paginator->hasMorePages())
????????????????<li class="page-item">
????????????????????<a class="page-link" href="{{ $paginator->nextPageUrl()?}}"?rel="next"?aria-label="@lang('pagination.next')">&rsaquo;</a>
????????????????</li>
????????????@else
????????????????<li class="page-item disabled" aria-disabled="true" aria-label="@lang(&#39;pagination.next&#39;)">
????????????????????<span class="page-link" aria-hidden="true">&rsaquo;</span>
????????????????</li>
????????????@endif
????????</ul>
????</nav>
@endif

這段程式碼是Laravel 預(yù)設(shè)的分頁視圖程式碼,我們可以將其拷貝到pagination.blade.php 檔案中,然後對(duì)其進(jìn)行自訂修改。

自訂樣式

自訂樣式就看開發(fā)者自己的喜好了,例如我們可以將分頁的連結(jié)修改為按鈕樣式:

<nav aria-label="Page navigation example">
??<ul class="pagination justify-content-center">
????@if?($paginator->onFirstPage())
????????<li class="page-item disabled"><span class="page-link">上一頁</span></li>
????@else
????????<li class="page-item"><a class="page-link" href="{{ $paginator->previousPageUrl()?}}">上一頁</a></li>
????@endif

????@foreach?($elements?as?$element)
????????@if?(is_string($element))
????????????<li class="page-item disabled"><span class="page-link">{{?$element?}}</span></li>
????????@endif

????????@if?(is_array($element))
????????????@foreach?($element?as?$page?=>?$url)
????????????????@if?($page?==?$paginator->currentPage())
????????????????????<li class="page-item active"><span class="page-link">{{?$page?}}</span></li>
????????????????@else
????????????????????<li class="page-item"><a class="page-link" href="{{ $url }}">{{?$page?}}</a></li>
????????????????@endif
????????????@endforeach
????????@endif
????@endforeach

????@if?($paginator->hasMorePages())
????????<li class="page-item"><a class="page-link" href="{{ $paginator->nextPageUrl()?}}">下一頁</a></li>
????@else
????????<li class="page-item disabled"><span class="page-link">下一頁</span></li>
????@endif
??</ul>
</nav>

由於分頁連結(jié)通常不會(huì)太多,而且不同頁面的分頁連結(jié)樣式也可能不同,因此我們這裡只提供了一種簡(jiǎn)單的修改方式,開發(fā)者可以根據(jù)自己的需求靈活調(diào)整。

總結(jié)

透過本文的介紹,我們了解到了 Laravel 框架自帶的分頁類別是如何實(shí)現(xiàn)的,以及如何透過自訂視圖來修改分頁連結(jié)的樣式。當(dāng)然,這種自訂方式不僅限於分頁樣式,開發(fā)者也可以將它套用到其他各種佈局樣式中。

在實(shí)際開發(fā)中,優(yōu)秀的開發(fā)者總是能夠發(fā)現(xiàn)框架的潛力並且按照自己的需求進(jìn)行最佳化,這就是成為一個(gè)優(yōu)秀開發(fā)者所必須掌握的技術(shù)之一。希望本文能對(duì)大家有幫助,也希望大家能夠?qū)?Laravel 框架有更深入的了解與應(yīng)用。

以上是laravel怎麼實(shí)現(xiàn)自訂樣式的分頁功能的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

Laravel的政策是什麼,如何使用? Laravel的政策是什麼,如何使用? Jun 21, 2025 am 12:21 AM

InLaravel,policiesorganizeauthorizationlogicformodelactions.1.Policiesareclasseswithmethodslikeview,create,update,anddeletethatreturntrueorfalsebasedonuserpermissions.2.Toregisterapolicy,mapthemodeltoitspolicyinthe$policiesarrayofAuthServiceProvider.

如何在操作系統(tǒng)(Windows,MacOS,Linux)上安裝Laravel? 如何在操作系統(tǒng)(Windows,MacOS,Linux)上安裝Laravel? Jun 19, 2025 am 12:31 AM

是的,YouCaninStallaLaveRonanyOperatingSystembyFollowingTheSeSteps:1.InstallphpandRequiredExtensionsLikeMbString,OpenSSL,AndxmlusingtoolslikeXampponwindows,HomebrewhonMacos,HomebrewonMacos,homebbrewonmacos,homebtonlinux,oraptonlinux;

Laravel中的控制器是什麼,他們的目的是什麼? Laravel中的控制器是什麼,他們的目的是什麼? Jun 20, 2025 am 12:31 AM

控制器在Laravel中的主要作用是處理HTTP請(qǐng)求並返迴響應(yīng),以保持代碼的整潔和可維護(hù)性。通過將相關(guān)請(qǐng)求邏輯集中到一個(gè)類中,控制器使路由文件更簡(jiǎn)潔,例如將用戶資料展示、編輯和刪除等操作分別放在UserController的不同方法中。創(chuàng)建控制器可通過Artisan命令phpartisanmake:controllerUserController實(shí)現(xiàn),而資源控制器則使用--resource選項(xiàng)生成,涵蓋標(biāo)準(zhǔn)CRUD操作的方法。接著需在路由中綁定控制器,如Route::get('/user/{id

如何自定義Laravel中的身份驗(yàn)證視圖和邏輯? 如何自定義Laravel中的身份驗(yàn)證視圖和邏輯? Jun 22, 2025 am 01:01 AM

Laravel允許通過覆蓋默認(rèn)存根和控制器來自定義認(rèn)證視圖和邏輯。 1.要自定義認(rèn)證視圖,可使用命令phpartisanvendor:publish--tag=laravel-auth將默認(rèn)Blade模板複製到resources/views/auth目錄並進(jìn)行修改,例如添加“服務(wù)條款”複選框。 2.要修改認(rèn)證邏輯,需調(diào)整RegisterController、LoginController和ResetPasswordController中的方法,如更新validator()方法以驗(yàn)證新增字段,或重寫r

如何使用Laravel的驗(yàn)證系統(tǒng)來驗(yàn)證形式數(shù)據(jù)? 如何使用Laravel的驗(yàn)證系統(tǒng)來驗(yàn)證形式數(shù)據(jù)? Jun 22, 2025 pm 04:09 PM

Laravelprovidesrobusttoolsforvalidatingformdata.1.Basicvalidationcanbedoneusingthevalidate()methodincontrollers,ensuringfieldsmeetcriterialikerequired,maxlength,oruniquevalues.2.Forcomplexscenarios,formrequestsencapsulatevalidationlogicintodedicatedc

如何使用{{{{...}}}在刀片模板中逃脫HTML輸出? (注意:很少使用,更喜歡{{...}}) 如何使用{{{{...}}}在刀片模板中逃脫HTML輸出? (注意:很少使用,更喜歡{{...}}) Jun 23, 2025 pm 07:29 PM

inlaravelBladeTemplates,使用{{{...}}} todisplayrawhtml.bladeescapescontentwithin {{...}} fullhtmlspecialchars() ks.但是,三重橋式播放,呈現(xiàn),呈現(xiàn)thtmlas-is.thisshouldbodedspareSpareDandanlylythlylythlylythlusteddata.Acceptablecase

選擇特定的列|性能優(yōu)化 選擇特定的列|性能優(yōu)化 Jun 27, 2025 pm 05:46 PM

1.FetchingAllColumnSIncreaseSemory,網(wǎng)絡(luò)和ProPersingSingoverHead.2.unnectaryDatareTrievalPreventSefefectivefectivefective.2.nynynyneedcolumnsimprovesperformenceByReDucingReSouranceByReDucingRessourceUsage.1.fetchingallcolumnsincreasemory

我如何在Laravel測(cè)試中模擬依賴項(xiàng)? 我如何在Laravel測(cè)試中模擬依賴項(xiàng)? Jun 22, 2025 am 12:42 AM

tomockDepentencies forcectiesInallaravel,distrypentenceptionforservices,syseReceive()forfacades,andmockeryforcomplexcases.1.forinjectedServices,使用$ this-> instance()tore-> instance()

See all articles