Hello developers! In this article, we'll create laravel 10 and Livewire to create a select2 dropdown that'll elevate the user experience of our web applications. Select2 is known for its sleek, feature-rich dropdowns, and combining it with the power of Livewire in Laravel 10 makes for a winning combination.
Here, we'll create a Select2 dropdown component. and also we'll use select2 cdn files.
In this step, we'll install the laravel 10 application using the following command.
laravel new my-livewire-project
cd my-livewire-project
Next, we'll install Livewire using the following command.
composer require livewire/livewire
Then, we'll create a livewire component to handle our Select2 dropdown.
php artisan make:livewire Select2Dropdown
This will create a Select2Dropdown.php
file in the app/Http/Livewire
directory.
Open the Select2Dropdown.php
file and define the Livewire component's view in the render
method. We'll also include the Select2 CDN links.
app/Http/Livewire/Select2Dropdown.php
<?php
namespace App\Http\Livewire;
use Livewire\Component;
class Select2 extends Component
{
public $selCity = '';
public $cities = [
'Newyork',
'London',
'Texas',
];
/**
* Write code on Method
*
* @return response()
*/
public function render()
{
return view('livewire.select2-dropdown')->extends('layouts.app');
}
}
Now, create a new blade file at resources/views/livewire/select2-dropdown.blade.php
:
<div>
<h1>Laravel 10 Livewire Create Select2 Dropdown - Vidavtek</h1>
<strong>Select2 Dropdown: {{ $selCity }}</strong>
<div wire:ignore>
<select class="form-control" id="select2" >
<option value=""> Select City </option>
@foreach($cities as $city)
<option value="{{ $city }}">{{ $city }}</option>
@endforeach
</select>
</div>
</div>
@push('scripts')
<script>
$(document).ready(function() {
$('#select2').select2();
$('#select2').on('change', function (e) {
var data = $('#select2').select2("val");
@this.set('selCity', data);
});
});
</script>
@endpush
Create routes into the routes/web.php file.
<?php
use Illuminate\Support\Facades\Route;
use App\Http\Livewire\Select2Dropdown;
/*
|--------------------------------------------------------------------------
| Web Routes
|--------------------------------------------------------------------------
|
| Here is where you can register web routes for your application. These
| routes are loaded by the RouteServiceProvider within a group which
| contains the "web" middleware group. Now create something great!
|
*/
Route::get('select2', Select2Dropdown::class);
In your main blade file (e.g., resources/views/layouts/app.blade.php
), include the Livewire and Select2 scripts:
<!DOCTYPE html>
<html>
<head>
<title>Laravel 10 Livewire Create Select2 Dropdown - Vidvatek</title>
@livewireStyles
<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<link href="//maxcdn.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css" rel="stylesheet" id="bootstrap-css">
<script src="//maxcdn.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js"></script>
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/select2.min.css" rel="stylesheet" />
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/select2.min.js"></script>
</head>
<body>
<div class="container">
@yield('content')
</div>
</body>
@livewireScripts
@stack('scripts')
</html>
Now, run the laravel 10 application using the following command.
php artisan serve
You might also like:
- Read Also: Laravel 10 Filter Datatable with Dropdown
- Read Also: Select2 Autocomplete Search Using Ajax in Laravel 10
- Read Also: How to Create Autocomplete Select Options Angular 17
- Read Also: How to Create Bar Chart in Laravel 10 using Apexcharts