Exciting news! Caleb has announced that Livewire v3 for Laravel is launching on July 20th at @LaraconUS. Let's take a look at some of the features Caleb announced back in 2022.
First, you no longer need to add the @livewireStyles or @livewireScripts directives. Just run composer require livewire/livewire, and you are good to go.
Livewire is now powered by Alpine and is included automatically as well.
Hot reloading out of the box, no build steps required 🔥 No need to refresh your browser anymore; Livewire takes care of everything and even preservers state 🤯
You can now use wire:transition to add smooth transitions to any of your HTML elements. This uses Alpine's x-transition directive behind the scene.
data:image/s3,"s3://crabby-images/844d5/844d57f3bb667e359e900f1492d9e109ec36f595" alt=""
You can now inject and call javascript from within your Livewire component class. This will eliminate the extra HTTP request.
data:image/s3,"s3://crabby-images/c60ba/c60ba750117aa784c12c6162e4cdd80cd8e1689e" alt=""
You can now lock properties to ensure they aren't modified by the user. Add the locked docblock above the property, and you are all set.
data:image/s3,"s3://crabby-images/3a0e4/3a0e435901c834a1d066599ab22fc800c7fc2b14" alt=""
That's not all; you can also use docblocks to format a given property. For example, you might want a Carbon date object to be formatted to 'd/m/y' when presented on the front-end.
data:image/s3,"s3://crabby-images/143f6/143f634766a6554fbfc85c135f5c2c0fcefc5359" alt=""
Livewire models are now deferred by default to minimize server requests. If you do want to make continuous updates, simply add ".live," and you are all set. This is a breaking change but is easy to fix with a quick find and replace.
data:image/s3,"s3://crabby-images/f2114/f21140144c7650434c7d6006880231e1fe35924b" alt=""
Component requests are now batched! 🤩
data:image/s3,"s3://crabby-images/f56db/f56dbbeb00fb29feb262137dfc2f5dfb7b3b381b" alt=""
Reactivity for nested components 🔥 You can use a docblock to define if a property should be reactive.
data:image/s3,"s3://crabby-images/9fdb4/9fdb4172f3ec5b54074c7d3971590cba5c89de39" alt=""
Save yourself some keystrokes by passing properties using this new syntax
data:image/s3,"s3://crabby-images/fafa5/fafa506efe69bb34151676ca31cddcfcaa8f406c" alt=""
You can now use Livewire components for things like input fields as well and make properties 'modelable', which is great when nesting components.
data:image/s3,"s3://crabby-images/d9719/d9719b146d78a9b6099b7241a7014338ca00526d" alt=""
When nesting components, you can use the new $parent variable to access the parent component. For example, this would trigger the 'sayHello' method on the parent component when pressing the enter key.
data:image/s3,"s3://crabby-images/91263/91263b5b57f8b44bd2248832ed61be24fcf274bc" alt=""
A new teleport directive allows you to teleport data to a different element on the page, even when this element lives outside your component!
data:image/s3,"s3://crabby-images/5ebd9/5ebd959a0aee720b9aa59b73f73a236ea361f80b" alt=""
SPA vibes using wire:navigate, you get snappy and almost instant responses 🚀
data:image/s3,"s3://crabby-images/26569/26569e36d2d73bb1395b6748c9b1d3f924f532df" alt=""
Use wire:navigate.prefetch to initiate the request once a user hovers the link to make it even snappier!
data:image/s3,"s3://crabby-images/451aa/451aab7f16c8cf39757871d768b2669a67ce5af5" alt=""
So many great features! And there might be even more; let's wait and see if Caleb will announce more amazing features at the LaraconUS launch event.