Installation | Laravel (2024)

Livewire is a Laravel package, so you will need to have a Laravel application up and running before you can install and use Livewire. If you need help setting up a new Laravel application, please see the official Laravel documentation.

To install Livewire, open your terminal and navigate to your Laravel application directory, then run the following command:

composer require livewire/livewire

That's it — really. If you want more customization options, keep reading. Otherwise, you can jump right into using Livewire.

/livewire/livewire.js returning a 404 status code

By default, Livewire exposes a route in your application to serve its JavaScript assets from: /livewire/livewire.js. This is fine for most applications, however, if you are using Nginx with a custom configuration, you may receive a 404 from this endpoint. To fix this issue, you can either compile Livewire's JavaScript assets yourself, or configure Nginx to allow for this.

#Publishing the configuration file

Livewire is "zero-config", meaning you can use it by following conventions, without any additional configuration. However, if needed, you can publish and customize Livewire's configuration file by running the following Artisan command:

php artisan livewire:publish --config

This will create a new livewire.php file in your Laravel application's config directory.

#Manually including Livewire's frontend assets

By default, Livewire injects the JavaScript and CSS assets it needs into each page that includes a Livewire component.

If you want more control over this behavior, you can manually include the assets on a page using the following Blade directives:

<html>

<head>

...

@livewireStyles

</head>

<body>

...

@livewireScripts

</body>

</html>

By including these assets manually on a page, Livewire knows not to inject the assets automatically.

AlpineJS is bundled with Livewire

Because Alpine is bundled with Livewire's JavaScript assets, you must include @livewireScripts on every page you wish to use Alpine. Even if you're not using Livewire on that page.

Though rarely required, you may disable Livewire's auto-injecting asset behavior by updating the inject_assets configuration option in your application's config/livewire.php file:

'inject_assets' => false,

If you'd rather force Livewire to inject its assets on a single page or multiple pages, you can call the following global method from the current route or from a service provider.

\Livewire\Livewire::forceAssetInjection();

#Configuring Livewire's update endpoint

Every update in a Livewire component sends a network request to the server at the following endpoint: https://example.com/livewire/update

This can be a problem for some applications that use localization or multi-tenancy.

In those cases, you can register your own endpoint however you like, and as long as you do it inside Livewire::setUpdateRoute(), Livewire will know to use this endpoint for all component updates:

Livewire::setUpdateRoute(function ($handle) {

return Route::post('/custom/livewire/update', $handle);

});

Now, instead of using /livewire/update, Livewire will send component updates to /custom/livewire/update.

Because Livewire allows you to register your own update route, you can declare any additional middleware you want Livewire to use directly inside setUpdateRoute():

Livewire::setUpdateRoute(function ($handle) {

return Route::post('/custom/livewire/update', $handle)

->middleware([...]);

});

#Customizing the asset URL

By default, Livewire will serve its JavaScript assets from the following URL: https://example.com/livewire/livewire.js. Additionally, Livewire will reference this asset from a script tag like so:

<script src="/livewire/livewire.js" ...

If your application has global route prefixes due to localization or multi-tenancy, you can register your own endpoint that Livewire should use internally when fetching its JavaScript.

To use a custom JavaScript asset endpoint, you can register your own route inside Livewire::setScriptRoute():

Livewire::setScriptRoute(function ($handle) {

return Route::get('/custom/livewire/livewire.js', $handle);

});

Now, Livewire will load its JavaScript like so:

<script src="/custom/livewire/livewire.js" ...

#Manually bundling Livewire and Alpine

By default, Alpine and Livewire are loaded using the <script src="livewire.js"> tag, which means you have no control over the order in which these libraries are loaded. Consequently, importing and registering Alpine plugins, as shown in the example below, will no longer function:

// Warning: This snippet demonstrates what NOT to do...

import Alpine from 'alpinejs'

import Clipboard from '@ryangjchandler/alpine-clipboard'

Alpine.plugin(Clipboard)

Alpine.start()

To address this issue, we need to inform Livewire that we want to use the ESM (ECMAScript module) version ourselves and prevent the injection of the livewire.js script tag. To achieve this, we must add the @livewireScriptConfig directive to our layout file (resources/views/components/layouts/app.blade.php):

<html>

<head>

<!-- ... -->

@livewireStyles

@vite(['resources/js/app.js'])

</head>

<body>

{{ $slot }}

@livewireScriptConfig

</body>

</html>

When Livewire detects the @livewireScriptConfig directive, it will refrain from injecting the Livewire and Alpine scripts. If you are using the @livewireScripts directive to manually load Livewire, be sure to remove it. Make sure to add the @livewireStyles directive if it is not already present.

The final step is importing Alpine and Livewire in our app.js file, allowing us to register any custom resources, and ultimately starting Livewire and Alpine:

import { Livewire, Alpine } from '../../vendor/livewire/livewire/dist/livewire.esm';

import Clipboard from '@ryangjchandler/alpine-clipboard'

Alpine.plugin(Clipboard)

Livewire.start()

Rebuild your assets after composer update

Make sure that if you are manually bundling Livewire and Alpine, that you rebuild your assets whenever you run composer update.

Not compatible with Laravel Mix

Laravel Mix will not work if you are manually bundling Livewire and AlpineJS. Instead, we recommend that you switch to Vite.

#Publishing Livewire's frontend assets

Publishing assets isn't necessary

Publishing Livewire's assets isn't necessary for Livewire to run. Only do this if you have a specific need for it.

If you prefer the JavaScript assets to be served by your web server not through Laravel, use the livewire:publish command:

php artisan livewire:publish --assets

To keep assets up-to-date and avoid issues in future updates, we strongly recommend that you add the following command to your composer.json file:

{

"scripts": {

"post-update-cmd": [

// Other scripts

"@php artisan vendor:publish --tag=livewire:assets --ansi --force"

]

}

}

Installation | Laravel (2024)

FAQs

Installation | Laravel? ›

Via Laravel Installer

First, download the Laravel installer using Composer. Make sure to place the ~/. composer/vendor/bin directory in your PATH (or C:\%HOMEPATH%\AppData\Roaming\Composer\vendor\bin if working with Windows) so the laravel executable is found when you run the laravel command in your terminal.

How to install Laravel on terminal? ›

Via Laravel Installer

First, download the Laravel installer using Composer. Make sure to place the ~/. composer/vendor/bin directory in your PATH (or C:\%HOMEPATH%\AppData\Roaming\Composer\vendor\bin if working with Windows) so the laravel executable is found when you run the laravel command in your terminal.

How to check if Laravel is installed? ›

The quickest way to check your Laravel version is by using the php artisan --version command. Knowing which version of Laravel you are running and its specific details are crucial pieces of information, whether you're planning to upgrade, debug, or simply want to ensure compatibility with a specific feature.

Which command is used to install Laravel project? ›

Via Download. Once Composer is installed, download the 4.2 version of the Laravel framework and extract its contents into a directory on your server. Next, in the root of your Laravel application, run the php composer. phar install (or composer install ) command to install all of the framework's dependencies.

Where do I deploy my Laravel project? ›

To deploy Laravel apps, you need a server running a compatible operating system like Ubuntu. You also need several dependencies, like a web server, PHP, PHP extensions, Composer, Git, and a database. It's also possible to use NGINX or Apache. Meanwhile, popular databases for Laravel include MySQL and MongoDB.

Where do I put files in Laravel? ›

When using the local driver, all files that should be publicly accessible should be placed in the storage/app/public directory. Furthermore, you should create a symbolic link at public/storage which points to the storage/app/public directory.

How to install Laravel 10 using CMD? ›

Go inside the folder C:\xampp\htdocs> (if you are using xampp) or C:\wamp\www> (if you are using wamp) and open cmd/PoweShell & run the following commands: composer global require "laravel/installer" composer create-project laravel/laravel (after running this command a folder having name Laravel will be created there)

How to install on Terminal Server? ›

You can put a Terminal Services server in Install mode by using the Add/Remove Programs tool in Control Panel or by using the Install Application on the Terminal Server tool in Control Panel. The Install application on the Terminal Server tool is available when you install the Terminal Services role.

Top Articles
Latest Posts
Article information

Author: Fr. Dewey Fisher

Last Updated:

Views: 6003

Rating: 4.1 / 5 (62 voted)

Reviews: 85% of readers found this page helpful

Author information

Name: Fr. Dewey Fisher

Birthday: 1993-03-26

Address: 917 Hyun Views, Rogahnmouth, KY 91013-8827

Phone: +5938540192553

Job: Administration Developer

Hobby: Embroidery, Horseback riding, Juggling, Urban exploration, Skiing, Cycling, Handball

Introduction: My name is Fr. Dewey Fisher, I am a powerful, open, faithful, combative, spotless, faithful, fair person who loves writing and wants to share my knowledge and understanding with you.