Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pboivin/livewire-load-more-poc
"Load more" implementation using Laravel Livewire
https://github.com/pboivin/livewire-load-more-poc
Last synced: about 1 month ago
JSON representation
"Load more" implementation using Laravel Livewire
- Host: GitHub
- URL: https://github.com/pboivin/livewire-load-more-poc
- Owner: pboivin
- Created: 2022-07-09T20:30:16.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-07-14T15:44:36.000Z (over 2 years ago)
- Last Synced: 2024-10-15T07:27:23.691Z (3 months ago)
- Language: PHP
- Homepage:
- Size: 95.7 KB
- Stars: 10
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Load more implementation using Laravel Livewire
### Introduction
This is a proof of concept on how to implement a Load more style listing with Livewire.
There are a few articles online presenting one approach that can be summarized in this way:
- Start with a query loading the first N results (first page)
- When 'Load more' is clicked, the same query is run loading N*2 results (first and second pages)
- And so on, for all remaining pagesThis works well for a small number of items/pages but is obviously not very efficient as the original DB query simply grows from page to page.
The solution presented here takes a different approach:
- On the initial page load, preload all item IDs and group them into chunks (pages)
- Start with a query loading the first chunk of results (first page)
- When 'Load more' is clicked, load the next chunk of results (next page)### Pros and Cons
Because [Livewire nested components are not reactive](https://laravel-livewire.com/docs/2.x/nesting-components) (ie. not rerendered when the parent component is updated), this ensures that only the new chunk of items is handled on subsequent clicks to 'Load more'.
The main cost of this solution is querying all IDs upfront. This is most likely not an issue with a well indexed DB table. However, it does freeze the initial set of results, on the initial page load.
### Demo
The demo introduces 2 Livewire components:
- `PostList` [(class)](https://github.com/pboivin/livewire-load-more-poc/blob/main/app/Http/Livewire/PostList.php) [(view)](https://github.com/pboivin/livewire-load-more-poc/blob/main/resources/views/livewire/post-list.blade.php) - Performs the inital query and handles the 'Load more' functionality
- `PostListItems` [(class)](https://github.com/pboivin/livewire-load-more-poc/blob/main/app/Http/Livewire/PostListItems.php) [(view)](https://github.com/pboivin/livewire-load-more-poc/blob/main/resources/views/livewire/post-list-items.blade.php) - Loads and displays the items for a single page### Alternative
Check out the ['paginator' branch](https://github.com/pboivin/livewire-load-more-poc/tree/paginator) [(diff)](https://github.com/pboivin/livewire-load-more-poc/commit/eba7253b1457dfeaf352a4e65ff3c78ec77e4d21) for a variation using a regular paginated query instead of the full list of IDs.
### Local Setup
Prerequisites:
- PHP >= 8.0
- Composer```
composer i
cp .env.example .env
touch database/database.sqlite
php artisan migrate --seed
php artisan serve
```