페이지 매김 예제를 사용한 Laravel 9 단순 검색
16606 단어 phplaraveltailwindcsswebdev
라라벨 프로젝트 생성
laravel 프로젝트를 생성하려면 터미널에서 아래 명령을 실행하십시오.
composer create-project laravel/laravel laravel-search
라라벨 브리즈를 설치합니다.
Laravel 9 Authentication with Laravel Breeze
사용자 가짜 데이터 생성
Laravel 제공자는 시더의 주석을 제거하고 시더를 실행하기만 하면 필요한 데이터를 가짜로 만듭니다.
데이터베이스/시드/DatabaseSeeder.php
<?php
namespace Database\Seeders;
use Illuminate\Database\Seeder;
class DatabaseSeeder extends Seeder
{
/**
* Seed the application's database.
*
* @return void
*/
public function run()
{
\App\Models\User::factory(20)->create();
// \App\Models\User::factory()->create([
// 'name' => 'Test User',
// 'email' => '[email protected]',
// ]);
}
}
마이그레이션과 함께 시더를 실행합니다.
php artisan migrate:fresh --seed
사용자 컨트롤러 만들기
아래 명령을 실행하여 사용자 컨트롤러를 생성하십시오.
php artisan make:controller UserController
페이지 매김으로 검색 기능을 추가하십시오.
앱/Http/UserController.php
<?php
namespace App\Http\Controllers;
use App\Models\User;
use Illuminate\Http\Request;
class UserController extends Controller
{
public function index(Request $request)
{
$users = User::where([
['name', '!=', Null],
[function ($query) use ($request) {
if (($s = $request->s)) {
$query->orWhere('name', 'LIKE', '%' . $s . '%')
->orWhere('email', 'LIKE', '%' . $s . '%')
->get();
}
}]
])->paginate(6);
return view('users.index', compact('users'));
}
}
web.php
<?php
use App\Http\Controllers\UserController;
use Illuminate\Support\Facades\Route;
/*
|--------------------------------------------------------------------------
| 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('/', function () {
return view('welcome');
});
Route::get('/dashboard', function () {
return view('dashboard');
})->middleware(['auth'])->name('dashboard');
Route::get('users', [UserController::class,'index'])->name('users.search');
require __DIR__.'/auth.php';
검색 형식으로 사용자 블레이드 파일을 만듭니다.
조회수/사용자/index.blade.php
<x-app-layout>
<x-slot name="header">
<h2 class="text-xl font-semibold leading-tight text-gray-800">
{{ __('Users') }}
</h2>
</x-slot>
<div class="py-12">
<div class="mx-auto max-w-7xl sm:px-6 lg:px-8">
<div class="overflow-hidden bg-white shadow-sm sm:rounded-lg">
<div class="p-6 bg-white border-b border-gray-200">
<div class="mt-1 mb-4">
<div class="relative max-w-xs">
<form action="{{ route('users.search') }}" method="GET">
<label for="search" class="sr-only">
Search
</label>
<input type="text" name="s"
class="block w-full p-3 pl-10 text-sm border-gray-200 rounded-md focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400"
placeholder="Search..." />
<div class="absolute inset-y-0 left-0 flex items-center pl-4 pointer-events-none">
<svg xmlns="http://www.w3.org/2000/svg" class="w-5 h-5 text-gray-400" fill="none"
viewBox="0 0 24 24" stroke="currentColor" stroke-width="2">
<path stroke-linecap="round" stroke-linejoin="round"
d="M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z" />
</svg>
</div>
</form>
</div>
</div>
<div class="relative overflow-x-auto shadow-md sm:rounded-lg">
<table class="w-full text-sm text-left text-gray-500 dark:text-gray-400">
<thead
class="text-xs text-gray-700 uppercase bg-gray-50 dark:bg-gray-700 dark:text-gray-400">
<tr>
<th scope="col" class="px-6 py-3">
#
</th>
<th scope="col" class="px-6 py-3">
Name
</th>
<th scope="col" class="px-6 py-3">
Email
</th>
</tr>
</thead>
<tbody>
@foreach ($users as $user)
<tr class="bg-white border-b dark:bg-gray-800 dark:border-gray-700">
<th scope="row"
class="px-6 py-4 font-medium text-gray-900 dark:text-white whitespace-nowrap">
{{$user->id}}
</th>
<td class="px-6 py-4">
{{$user->name}}
</td>
<td class="px-6 py-4">
{{$user->email}}
</td>
</tr>
@endforeach
</tbody>
</table>
{{ $users->links() }}
</div>
</div>
</div>
</div>
</div>
</x-app-layout>
Reference
이 문제에 관하여(페이지 매김 예제를 사용한 Laravel 9 단순 검색), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/larainfo/laravel-9-simple-search-with-pagination-example-723텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)