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

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

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

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

11452閲覧

CakePHP3の検索後のページングについて

ssk

総合スコア332

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

1クリップ

投稿2017/01/26 18:48

PHP

1//PagingSupportComponent.php 2 3namespace App\Controller\Component; 4use Cake\Controller\Component; 5use Cake\Core\Configure; 6 7/** 8 * 既存のページング機能をサポートするコンポーネント 9 */ 10 11class PagingSupportComponent extends Component { 12 13 var $_controller = null; 14 var $_sessionName = ''; 15 16 function startup( & $controller ) { 17 $this->_controller = $controller; 18 $this->_sessionName = $this->_getSessionName( $controller->params ); 19 } 20 21 /** 22 * controller->data の値の引き継ぎを行う 23 */ 24 function inheritPostData(){ 25 26 if( !empty( $this->_controller->data ) ){ 27 $this->request->session()->write( $this->_sessionName, $this->_controller->data ); 28 } 29 elseif( !empty( $this->_controller->params['named']['page'] ) && $this->request->session()->check( $this->_sessionName ) ){ 30 $this->_controller->data = $this->request->session()->read( $this->_sessionName ); 31 } 32 else{ 33 $this->request->session()->delete( $this->_sessionName ); 34 } 35 } 36 37 /** 38 * 現在引き継がれているPostDataを取得 39 * @param $params = array( 'controller' => ..., 'action' => ... ) 40 * @return array 41 */ 42 function getInheritPostdata( $params ){ 43 if( $this->request->session()->check( $this->_getSessionName( $params ) ) ){ 44 return $this->request->session()->read( $this->_getSessionName( $params ) ); 45 } 46 else{ 47 return null; 48 } 49 } 50 51 /** 52 * SESSIONに使用する名前を取得 53 */ 54 private function _getSessionName( $params ){ 55 return 'pagingSupport_' . $params['controller'] . $params['action']; 56 } 57}

PHP

1//HogesController.php 2 3$this->PagingSupport->inheritPostData(); //$this->dataの値の引き継ぎが行われる 4$conditions = array(); 5if( !empty( $this->request->data ) ){ 6 $conditions = $this->request->params['paging'] ; //検索フォームの入力値から conditions を取得 7 } 8 9$this->set('hoges', $this->paginate( 'Hoges', $conditions) );

######問題
$conditions = $this->request->params['paging'] ;
$conditionsに入れる内容が間違っていると思っています。
ただ、何を入れたらいいかわからず、困っています。

######補足
テーブル検索後にページングがうまく動かないため

cakephpのページング時の検索条件の引き継ぎ
こちらを参考にしました。

内容が少し古かったので
$this->Session

$this->request->session()
に変更しています。

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

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

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

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

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

popobot

2017/01/26 23:10 編集

そもそも参考にしている情報が古い気がしました...。なおPOSTではなくGETでいいなら、わざわざ検索条件をセッションにしまう必要すらないのですが。
ssk

2017/01/27 03:50

古いとは思いつつ、情報が少なかったため こちらで対応しようと考えていました。 やりたいことは ・検索条件の引き継ぎ ・検索後のページング です。 なのでicchii様がおっしゃるようにGETで問題ありません。 教えていただけると助かります。
guest

回答1

0

ベストアンサー

確かに参考になりそうなサイトがあまりないですね...
以下、Hogesテーブルのtitleカラムをlike検索する例です。

template側

php

1<?= $this->Form->create(null, ['type' => 'get']) ?> 2<?= $this->Form->input('title', ['value' => $this->request->query('title')]) ?> 3<?= $this->Form->submit() ?> 4<?= $this->Form->end() ?> 5 6<?= $this->Paginator->numbers() ?>

※Paginatorヘルパーは、Queryパラメータ(title=xxx)を自動的に引き継いでくれるので、条件が引き継いだパージネートが可能です。

controller側

php

1$query = $this->Hoges->find(); 2if(!empty($this->request->query('title'))) { 3 $query->where(['title LIKE' => '%'.$this->request->query('title').'%']); 4} 5$hoges = $this->paginate($query); 6$this->set(compact('hoges'));

※条件指定したqueryをpaginateにセットするだけ

マニュアルを良く読みましょう。すべてのケースについて記載はありませんし、英語しかない場合もありますが、参考になるはずです。

投稿2017/01/27 04:28

編集2017/01/27 04:49
popobot

総合スコア6586

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

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

ssk

2017/01/27 05:41

ありがとうございます! 検索後のページネーション、実現できました。 セッションよりも断然簡単でした。。 2ページ目以降の検索条件の引き継ぎも以下で実装できました。 echo $this->Form->input('column01',[ 'value' => $this->request->query('value01'), ]); ご助言、ありがとうございました><
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問