Loading States
cbwire via Livewire uses AJAX requests to invoke component actions on our wire objects. There are cases when this may involve a long-running process, such as completing a cart checkout, and the page may not respond instantly to a user event like a click. cbwire allows you to effortlessly display loading states, such as showing and hiding elements, adding and removing classes, or toggling HTML attributes until the server responds.
Loading States can make your apps feel responsive and user-friendly.
Toggling Elements
Let's take a look at a checkout action that takes too long.
We can annotate our <div>
with wire:loading
to display Processing Payment while the checkout action is running.
After the checkout action completes, the Processing Payment output will disappear. 👋
Toggling Attributes
Delay Loading State
Sometimes your component actions complete at the speed of light, and the user doesn't have enough time to see the elements you want to be displayed. You can add a .delay
modifier to delay showing your HTML elements for 200ms.
Display Property
Loading State elements are set with a CSS property of display: inline-block;
by default. You can override this behavior by using various annotation modifiers.
Hide During Loading State
If you would like to display an element EXCEPT during a loading state, you can apply the wire:loading.remove
annotation.
Last updated