Laravel Livewire An Introduction

Laravel Livewire – An Introduction


Ever thought of the possibility of writing reactive components in your application that has the capability of managing state, re-rendering as required and doing all the other interesting stuff, without writing any line of Javascript??
Say hello to Laravel Livewire.

Livewire, as described on https://laravel-livewire.com/, is a full-stack framework for Laravel that makes building dynamic front-ends as simple as writing vanilla PHP.

In this tutorial, we are going to get introduced to livewire, build a simple Laravel livewire component so we see how it all works and discuss when to use it and when not to.

Setting Up

As described above, livewire is a framework for laravel. Hence we need Laravel to use livewire.
If you already have laravel installed on your computer, run the following snippet to create a simple laravel project.


laravel new learn-livewire

If you don’t have laravel installed, you can install laravel by running:


composer global require laravel/installer

When that is done, create a new laravel project by running the same snippet as shown above:


laravel new learn-livewire

After creating the project, move into the learn-livewire folder by running:


cd learn-livewire

We can now install livewire in this project


composer require livewire/livewire

Creating a Livewire Component

Livewire is a component-driven framework. It takes ideas from javascript frameworks and brings them to PHP.
A Livewire component can be created by running:


php artisan make:livewire 

To create a counter component, we will run:


php artisan make:livewire counter

Livewire will create 2 files: Counter.php and counter.blade.php.

Counter.php is the component class. Here you define the properties in the state, the view to render, and other actions to take place based on user interaction.
If you are familiar with laravel, then counter.blade.php should be familiar. Yes, livewire uses the blade templating engine which we are used to. counter.blade.php is the view file for the Counter component. counter.blade.php can be found at resources/views/livewire/.

The Component Class

The content of Counter.php should be similar to this:


<?php
namespace App\Http\Livewire;
use Livewire\Component;
class Counter extends Component
{
    public function render()
    {
        return view('livewire.counter');
    }
}

The render method is a compulsory method and must be in your livewire component. It tells livewire the view that is associated with this component. Here, we are returning the livewire.counter view. 

Again, if you are used to laravel, this should be familiar as it is the same way views are rendered in laravel.
If we move the location of our view file, we will need to update the render function to reflect its new location.

The Component View

Livewire uses laravel blade, which is native to laravel for its templating.
The view file for your component must have exactly one root HTML element. This rule is similar to that of vue templates.

The view file has access to all public properties that were defined in the class.
In raw laravel, we will need to explicitly send these properties to the view but with livewire, that is done out of the box for public properties. Hence, any property that isn’t used in the view should have either protected or private accessibility.

Let’s modify the view file to show some simple content.
Edit counter.blade.php to:


<div>
    <p>Counting ... 0</p>
    <button>+</button>
    <button>-</button>
</div>

After creating the component, we make it display in a page by adding it to the page as such:


@livewire('componentName')

All laravel projects come with a default page — welcome.blade.php, which can be found at resources/views/. Open it up in your text editor and include the livewire component.
You might want to remove all the default laravel sample text that’s contained in the file.
Add the following to the body section of welcome.blade.php

@livewire('counter')

Run the laravel server via:

php artisan serve

The counter component should be showing on the browser

Congratulations!!!
You have successfully written your first Livewire component.

Making the Component Interactive

Livewire provides a technique to listen to browser events. Events can be listened by adding `wire:<eventName>` to the element we want to listen on.


<button wire:click="performAction">Click Me</button>

For example, if we want to listen on a button for the click event, we would do that as:

For this to work as expected, @livewireScripts needs to be added to the page which the component will be used.

The action to be performed is a function that was defined in the component class.

Let’s add some interactivity to our counter component.
Modify Counter.php to


<?php
namespace App\Http\Livewire;
use Livewire\Component;
class Counter extends Component
{
    public $count = 0;
    public function increment() {
        $this->count += 1;
    }
    public function render()
    {
        return view('livewire.counter');
    }
}

We need to update the view to use the $count variable created and also to call increment().


<div>
    <p>Counting ... {{$count}}</p>
    <button wire:click='increment'>+</button>
    <button>-</button>
</div>

Go back to the browser and watch it happen.
Endeavour to add @livewireScripts to welcome.blade.php since we are adding some interactivity.

Since that works, we can add the decrement functionality. Just as the increment functionality was added, create a decrement function (public) that handles the decrementing action, then wire dispatch the event with its corresponding action (decrement).

After doing this, counter.php should look like:


<?php
namespace App\Http\Livewire;
use Livewire\Component;
class Counter extends Component
{
    public $count = 0;
    public function increment() {
        $this->count += 1;
    }
    public function decrement() {
        $this->count -= 1;
    }
    public function render()
    {
        return view('livewire.counter');
    }
}

And counter.blade.php,


<div>
    <p>Counting ... {{$count}}</p>
    <button wire:click='increment'>+</button>
    <button wire:click='decrement'>-</button>
</div>

How It Works

If you open your dev tools and move to the network tab, you will notice that livewire sends a request when a click action is performed.
On every event that performs an action, livewire sends an ajax request to the backend with some data. This helps it update the state, and does any other function that is needed to be done in the action. It also returns a JSON response containing the new DOM state and some other information needed for rendering the new state to the DOM. 

When to Use Livewire

Occasionally, when building interactive applications, a click from the user will trigger: a state change on the frontend, send an ajax request to the backend and retain state on the frontend if the request was successful or revert to the previous state if the request fails.
Using livewire, there is only one source of truth — the backend. Hence, there will not be a case where the frontend isn’t in sync with the backend.

Conclusion

We’ve learnt about laravel livewire, how it works and when to use it.
So go wire up some components!!!


Share on social media

//