How to install laravel 9
https://tutorial101.blogspot.com/2022/02/how-to-install-laravel-9.html
Connecting our Database
open .env file root directory.
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laraveldb
DB_USERNAME=root
DB_PASSWORD=
Create tables
php artisan make:migration create_countries_table
C:\xampp\htdocs\laravel\laravelproject>php artisan make:migration create_countries_table
Open new migrations
yourproject/database/migrations
laravelproject\database\migrations\create_countries_table.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | //laravelproject\database\migrations\create_countries_table.php <?php return new class extends Migration { public function up() { Schema::create( 'countries' , function (Blueprint $table ) { $table ->id(); $table ->string( 'country_code' ); $table ->string( 'country_name' ); $table ->timestamps(); }); } }; |
php artisan migrate
C:\xampp\htdocs\laravel\laravelproject>php artisan migrate
Migration table created successfully.
check database table
Create tables Model
php artisan make:model Countries
Creating Controller
php artisan make:controller AutocompleteController
C:\xampp\htdocs\laravel\laravelproject>php artisan make:controller AutocompleteController
change it with the following codes:
laravelproject\app\Http\Controllers\AutocompleteController.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | //laravelproject\app\Http\Controllers\AutocompleteController.ph <?php namespace App\Http\Controllers; use Illuminate\Http\Request; use DB; class AutocompleteController extends Controller { function index() { return view( 'autocomplete' ); } function fetch(Request $request ) { if ( $request ->get( 'query' )) { $query = $request ->get( 'query' ); $data = DB::table( 'countries' ) ->where( 'country_name' , 'LIKE' , "%{$query}%" ) ->get(); $output = '<ul class="dropdown-menu" style="display:block; position:relative;width:100%;">' ; foreach ( $data as $row ) { $output .= ' <li><a class = "dropdown-item" href= "#" > '.$row->country_name.' </a></li> '; } $output .= '</ul>' ; echo $output ; } } } |
laravelproject\routes\web.php
1 2 3 4 5 6 7 8 9 10 11 | //laravelproject\routes\web.php <?php use Illuminate\Support\Facades\Route; use App\Http\Controllers\AutocompleteController; //add DepartmentsController Route::get( '/' , function () { return view( 'welcome' ); }); Route::get( '/autocomplete' , [AutocompleteController:: class , 'index' ]); Route::post( '/autocomplete/fetch' , [AutocompleteController:: class , 'fetch' ])->name( 'autocomplete.fetch' ); |
laravelproject\resources\views\autocomplete.blade.phpp
Bootstrap 5 https://getbootstrap.com/docs/5.0/getting-started/introduction/
https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css
Jquery
https://jquery.com/download/
CDN : jsDelivr CDN
https://www.jsdelivr.com/package/npm/jquery
https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | //laravelproject\resources\views\autocomplete.blade.php <!DOCTYPE html> <html> <head> <title>Laravel 9 Autocomplete Textbox with JQuery Ajax</title> <link rel= "stylesheet" href= "https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" /> <style type= "text/css" > .box{ width:600px; margin:0 auto; } </style> </head> <body> <p style= "padding:20px;" ><h3 align= "center" >Laravel 9 Autocomplete Textbox with JQuery Ajax</h3></p> <div class = "container box" > <div class = "form-group" > <input type= "text" name= "country_name" id= "country_name" class = "form-control" placeholder= "Enter Country Name" /> <div id= "countryList" ></div> </div> {{ csrf_field() }} </div> <script> $(document).ready( function (){ $( '#country_name' ).keyup( function (){ var query = $(this).val(); if (query != '' ) { var _token = $( 'input[name="_token"]' ).val(); $.ajax({ url: "{{ route('autocomplete.fetch') }}" , method: "POST" , data:{query:query, _token:_token}, success: function (data){ $( '#countryList' ).fadeIn(); $( '#countryList' ).html(data); } }); } }); $(document).on( 'click' , 'li' , function (){ $( '#country_name' ).val($(this).text()); $( '#countryList' ).fadeOut(); }); }); </script> </body> </html> |
Starting Laravel development server: http://127.0.0.1:8000