How does Laravel use the Pagination plug-in to implement custom pagination? This article mainly introduces the relevant information about the PHP framework Laravel5.1 plug-in Pagination to implement custom paging. Friends in need can refer to it. I hope to be helpful.
Laravel's pagination is very convenient. In fact, it is also very easy to extend. Let's do an example below to extend the paginate() and simplePaginate() methods to implement our custom paging style, such as displaying "Up "One page" and "Next page" instead of """ and """. Of course, if you master the expansion method, you can expand a paging you want without restraint, such as jumping to a certain page and displaying the paging. How many records are there in total, the range of records currently displayed, and so on. . .
5.1 and 5.2 should be the same method. I am using the 5.2 version here. The documentation tells us that Paginator corresponds to the query builder and Eloquent's simplePaginate method, while LengthAwarePaginator is equivalent to the paginate method. Then let's take a look at the source code. Specifically, how does paginate implement render()?
Illuminate/Pagination/LengthAwarePaginator.php
render(); } ...... }
render() What is entered is an instance of Presenter, and the render method of this instantiation is called to realize paging display. If not, call render() in BootstrapThreePresenter to see what BootstrapThreePresenter does
Illuminate/Pagination/BootstrapThreePresenter.php
paginator = $paginator; $this->window = is_null($window) ? UrlWindow::make($paginator) : $window->get(); } /** * Determine if the underlying paginator being presented has pages to show. * * @return bool */ public function hasPages() { return $this->paginator->hasPages(); } /** * Convert the URL window into Bootstrap HTML. * * @return \Illuminate\Support\HtmlString */ public function render() { if ($this->hasPages()) { return new HtmlString(sprintf( '
You can see BootstrapThreePresenter here After implementing the interface of PresenterContract, render() is the real implementation of paging display. The first parameter PaginatorContract in the construction method is actually a Paginator. Let's continue to look at PresenterContract, which is what methods are defined in the Presenter interface and need to be implemented.
illuminate/contracts/Pagination/Presenter.php
Copy after login
The render and hasPages methods are defined and need to be implemented
Okay , then we are very clear now. If we want to customize the paging display, we need to write our own Presenter to implement render() and hasPages() in the interface.
First of all, let's simply implement a paginate() to display "previous page" and "next page", with an example of pagination numbers in the middle.
The new file is as follows (personal habit)
app/Foundations/Pagination/CustomerPresenter.php
paginator = $paginator; $this->window = is_null($window) ? UrlWindow::make($paginator) : $window->get(); } /** * Determine if the underlying paginator being presented has pages to show. * * @return bool */ public function hasPages() { return $this->paginator->hasPages(); } /** * Convert the URL window into Bootstrap HTML. * * @return \Illuminate\Support\HtmlString */ public function render() { if ($this->hasPages()) { return new HtmlString(sprintf( '
It’s that simple, the main thing is render() Method, if you need to modify the paging style in the project, or add pagination jumps and other requirements, you only need to rewrite the html elements in each displayed method. It is very flexible and needs to be modified in the blade template, such as Our Paginator is called $users, and the default paging display is like this:
{!! $users->render() !!}Modify it to our customized paging display :
{!! with(new \App\Foundations\Pagination\CustomerPresenter($categories))->render() !!}Okay, this should be enough on the page You can see that the pagination link contains the styles of "previous page" and "next page" plus numbers.
So what if you extend simplePaginate? It's actually very simple. You just need to inherit the CustomerPresenter just now and implement hasPages and render. As for why, you can just look at it the way I viewed the source code above. For example, we change it to "Previous article" "And" next article"
New App\Foundations\Pagination\CustomerSimplePresenter.php
paginator = $paginator; } /** * Determine if the underlying paginator being presented has pages to show. * * @return bool */ public function hasPages() { return $this->paginator->hasPages() && count($this->paginator->items()) > 0; } /** * Convert the URL window into Bootstrap HTML. * * @return \Illuminate\Support\HtmlString */ public function render() { if ($this->hasPages()) { return new HtmlString(sprintf( '
Pagination display:
{!! with(new \App\Foundations\Pagination\CustomerSimplePresenter($categories))->render() !!}
The method is this method, the specific modifications are according to your own You just need to rewrite the corresponding method of displaying html elements.
Related recommendations:
An elegant way to generate Gravatar avatar address using Laravel
Detailed explanation of Laravel reset password example
laravel writing APP interface (API)
The above is the detailed content of Laravel uses the Pagination plug-in to implement custom pagination. For more information, please follow other related articles on the PHP Chinese website!