Laravel Livewire infinite scroll
Hi there,
What you could do is follow the steps here:
- First in your Component Class add a listener:
protected $listeners = [
'load-more' => 'loadMore',
];
- After that add a public property which will be used to specify how many entries to be loaded:
public $numResults = 20;
- Then in your render method define your pagination as normal but inlcude the
numResults
proeprty:
public function render()
{
$posts = Post::query()
->where('status', 'active')
->orderBy('created_at', 'desc')
->paginate($this->numResults);
return view('livewire.posts', compact('posts'));
}
- Finally include the following JavaScript to detect when more posts have to be loaded:
<script type="text/javascript">
window.onscroll = function(ev) {
if ((window.innerHeight + window.scrollY) >= document.body.offsetHeight) {
window.livewire.emit('load-more');
}
};
</script>
- Finally in your view add a foreach method as usual
You can take a look at the following project as an example:
https://github.com/guildso/guild/blob/main/resources/views/livewire/posts.blade.php
https://github.com/guildso/guild/blob/main/app/Http/Livewire/Posts.php
Hope that this helps! Regards, Bobby
data:image/s3,"s3://crabby-images/1ed3e/1ed3ea78d53c9cba659e7d111b0d8fbb93dff30d" alt=""
data:image/s3,"s3://crabby-images/ee47d/ee47d69a1c76d62eaf225217a31a256fd6e926d3" alt=""
data:image/s3,"s3://crabby-images/a932c/a932cf72492b6fe8fb295c825e1644220e05ed16" alt=""
data:image/s3,"s3://crabby-images/1ed3e/1ed3ea78d53c9cba659e7d111b0d8fbb93dff30d" alt=""
data:image/s3,"s3://crabby-images/b45e6/b45e6c13d7bd61dda14a4b4015945ccf7eb0761d" alt=""
data:image/s3,"s3://crabby-images/df464/df464bbcdd1cd5e037559a4e449a8032fe3d4767" alt=""
data:image/s3,"s3://crabby-images/64aca/64acad70ecce986cfa9f5fb435af8fd66be9186d" alt=""
data:image/s3,"s3://crabby-images/44512/44512e5a067164b4aedb29646151b468a4d2b781" alt=""
data:image/s3,"s3://crabby-images/de6fb/de6fbd05f597f1d1f8f1ae487d464ef8ba0c7bc9" alt=""
data:image/s3,"s3://crabby-images/96b7a/96b7a57a15dc122455f0997fa6a4a75be4c18dd6" alt=""
data:image/s3,"s3://crabby-images/372c3/372c32913ca972ed89387ea779a1ee0fc87b84e4" alt=""
data:image/s3,"s3://crabby-images/68cb0/68cb05c1232893e023de1ec1e91eadf419fd0395" alt=""
data:image/s3,"s3://crabby-images/ee47d/ee47d69a1c76d62eaf225217a31a256fd6e926d3" alt=""
data:image/s3,"s3://crabby-images/5ebff/5ebff6fa149492a46cf4ac43606d00d647286cf9" alt=""
data:image/s3,"s3://crabby-images/7597a/7597a19cc815b5d911e0e8898b2e056fb9eec76f" alt=""
data:image/s3,"s3://crabby-images/45cf1/45cf179b29d40959e5812836d6b07094cdce4f3f" alt=""
data:image/s3,"s3://crabby-images/3e083/3e08337040f2226b6b6bab9b6ffba5c4bdef82ae" alt=""