質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

Q&A

解決済

2回答

749閲覧

ペジネーションで同一ページに検索機能と結果を表記したい

n18marron

総合スコア3

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

0グッド

0クリップ

投稿2021/08/10 03:47

編集2021/08/10 03:56

前提・実現したいこと

検索結果と検索フォームを同一ページに表示したいです。

発生している問題・エラーメッセージ

URLがhttp://127.0.0.1:8000/booksのときに検索すると問題なく結果が表示されます。
ですが、検索条件に当てはまる10件未満のデータは実際には存在していて、URLがhttp://127.0.0.1:8000/books?page=2のときに検索すると結果が得られません。データはありませんと表示されているだけになってしまいます。

該当のソースコード

// コントローラー public function index() { $datas = Book::paginate(10); return view('books.index', ['datas' => $datas]); } // 本を検索 public function search(Request $request) { $datas = Book::where('title', 'like', "%$request->title%")->paginate(10); return view('books.index', ['datas' => $datas]); }
// ビュー @extends('layouts.app') @section('title', '本一覧') @section('content') <form action="" method="post"> @csrf <input name="title" type="text"> <input type="submit" value="検索する"> </form> <br> @if(count($datas) != 0) @foreach($datas as $data) <a class="main_link"><a href="/books/edit/{{ $data->id }}" >{{ $data->title }}</a></a> @endforeach {{ $datas->links('components.pagination') }} @else データはありません @endif @endsection
// ルート Route::get('/books', [BookController::class, 'index']); Route::post('/books', [BookController::class, 'search']);

試したこと

public function redirection() {
return redirect('books');
}

// 本を検索 public function search(Request $request) { $this->redirection(); $datas = Book::where('title', 'like', "%$request->title%")->paginate(10); return view('books.index')->with(['datas' => $datas]); }

クエリに?pageがついているのでそれを除けば1ページ目に戻って検索結果が表示されると思いredirect処理をはさみましたがpageは除けませんでした。

補足情報(FW/ツールのバージョンなど)

Laravel 8.49.2

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

php

1$datas = Book::where('title', 'like', "%$request->title%") 2 ->paginate(10, 'pageno', $page);

となりますが、そうすると$pageが必要だとわかると思います
これはパラメータなので
$page = $request->input('page');
で取得できます、1が最初のページです(0でないのが、やや納得できないが)

投稿2021/09/30 23:37

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

自前の記事で恐縮なんですが、これを読んでください。ページネーションはあくまでテーブルの分割機能であって、検索結果の保持までしてくれないので、Sessionなどを用いて機能を補完していく必要があります。

Laravel標準のページネーションに検索機能を実装し、厄介な問題点に対応した

投稿2021/08/10 08:35

編集2021/08/10 08:40
FKM

総合スコア3647

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問