Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

Awesome Lists containing this project

README

        

# Load more implementation using Laravel Livewire

Demo

### 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 pages

This 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
```