CakePHP4のController内でViewテンプレート、レイアウトの変更設定を記述する方法
2024/09/08
CakePHP4のController内でViewテンプレート、レイアウトの指定はrenderを使用する
CakePHP4では、Controller内で Viewテンプレートや、レイアウトファイルをデフォルト以外のものに変更したいときは下記のように記述します。
1 |
$this->render(string $view, string $layout); |
上記を記述することで、Viewのテンプレート、および、レイアウトを指定する事ができます。
また、テンプレート、レイアウトを使用しない場合は、下記の記述をします。
1 2 3 4 |
// テンプレートファイルを使用しない場合 $this->autoRender = false; // レイアウトファイルを使用しない場合 $this->layout = false; |
CakePHP4でrenderに Viewを指定する具体的な記述方法の解説
具体的に、Controller内で Viewテンプレートや、レイアウトファイルをデフォルト以外のものに変更したいときの記述方法を解説します。
1 2 3 4 |
$view = "/element/sampleView"; $layout = "sampleLayout"; $this->render($view, $layout); |
「$view
」に編集するテンプレートのファイル名ですが、下記のルールがあります。
・拡張子の「.php」は記述しない
・標準フォルダ内にある場合はファイル名のみで OK
・「/
」から始めると「/templates」からの相対パスになる
デフォルト設定で処理される Viewについて
そのため、例えば、下記の Controller、Actionで処理をしているとします。
Controller名「Samples」
Action名「getData」
この場合、「render」でテンプレートを指定しないデフォルトの状態では下記のファイルをテンプレートとして使用します。
/templates/Samples/get_data.php
ここで注意が必要な点は、Action名は「getData」のようにローワーキャメルケースで記述しますが、テンプレートのファイル名は「get_data.php」のようにスネークケースで記述することになります。
これを間違えると下記の「テンプレートファイルがないよ」というエラーが発生します。
Missing Template
Cake\View\Exception\MissingTemplateException
Error The view for SamplesController::getData() was not found.
デフォルトのフォルダ内にある Viewを renderに指定をする方法
今度は、デフォルトのフォルダ内にある「get_image.php」というテンプレートファイルを使用したい場合の対応です。
下記のファイルを使用します。
/templates/Samples/get_image.php
この場合の renderに指定する記述方法は以下となります。
1 2 3 |
$view = "get_image"; $this->render($view); |
上記のように、「$view
」に「get_image」と、テンプレート名を指定します。
「$view = "getImage";
」のようにローワーキャメルケースで記述しても動作はしますが、公式 Cookbookでもスネークケースで記述してありますので、規約上はスネークケースで記述する方が正しいようです。
ちなみに、「$view = "getImage";
」と記述しても、テンプレートファイルは「get_image.php」である必要があり、「getImage.php」では読み込まれません。
フォルダのパスも含めて Viewを指定をする方法
最後は、フォルダのパスも含めて Viewのファイル名を指定する方法です。
下記のファイルを使用します。
/templates/element/get_record.php
この場合の renderに指定する記述方法は以下となります。
1 2 3 |
$view = "/element/get_record"; $this->render($view); |
上記のように、「$view
」に「/
」から始まるパスを記述すると「/templates」からの相対パスとして扱われます。
実ファイルを「/templates/element/getRecord.php
」とした場合、「$view = "getRecord";
」とすることで、テンプレートファイルを読み込むことはできます。
ですが、公式 Cookbookではスネークケースで記述してありますので、規約上はスネークケースで記述する方が正しいようです。
ファイル名がキャメルケースの「getRecord.php」である場合は renderにも「getRecord」と記述する必要があり、スネークケースの「get_record.php」である場合は renderにも「get_record」と記述する必要があるようです。
キャメルケース、スネークケースが混在している場合はエラーになります。
ちなみに、規約からは外れるようですが、
/templates/Samples/getData.php
上記のように、標準フォルダ内にキャメルケースで記述したファイルをテンプレートとして使用する場合は、
$view = "/Samples/getData";
のようにパス付でファイル名を指定する事で使用することは可能です。
「render()」を使用する際の注意点・renderは最後に書く理由
「render()」を使用する場合の注意点は
「$this->render(string $view, string $layout);
」は可能な限り Controller内の最後に書くことが必要です。
理由は単純です。
「$this->render(string $view, string $layout);
」の後に記述された「$this->set()
」の変数は受け取ることができないためです。
1 2 3 4 5 6 7 |
// 問題は発生しない順番 $this->set(compact("sampleData01","sampleData02")); $this->render("sampleView"); // 問題が発生する順番(変数を受け取れない) $this->render("sampleView"); $this->set(compact("sampleData01","sampleData02")); |
「render()」関数に限った話ではありませんし、CakePHP3のころも同じであったと思いますが、「render()」で指定したテンプレート内で使用する変数は、「render()」を記述するより前に「$this->set()
」で指定しておく必要があります。
順番が逆だと、Viewテンプレートでは変数を扱うことができませんので、「変数がないよ!」というエラーが発生します。
単純なことなだけにエラーが発生したときになかなか気づけない不具合とも言えます。
テンプレート、レイアウトを使用しない場合は autoRender、layoutに falseを指定する
前項までは、テンプレートファイル、レイアウトファイルを指定して使用する方法の解説でしたが、テンプレートファイル、レイアウトファイルを使用しない場合の設定方法を解説します。
1 2 3 4 |
// テンプレートファイルを使用しない場合 $this->autoRender = false; // レイアウトファイルを使用しない場合 $this->layout = false; |
記事の最初に書いたものと同じですが、大きなポイントは CakePHP3のころは利用できた下記の記述方法が使えなくなっている、という点です。
1 2 3 4 5 6 |
// テンプレート、レイアウトを無効にする方法 $this->render(false,false); // テンプレートだけ無効にする方法 $this->render(false,null); // レイアウトだけ無効にする方法 $this->render(null,false); |
そのため、「$this->autoRender = false;
」「$this->layout = false;
」をぞれぞれ指定する必要があるようです。
参考サイト
https://book.cakephp.org/4/ja/controllers.html
https://book.cakephp.org/4/ja/views.html
CakePHP4の関連記事
CakePHP4のFrozenDateで1ヵ月前、先月、今月1日、来月末の日付などを算出する方法CakePHP4のcake cache clear_allでPermission deniedはパーミッションの変更が必要
CakePHP4のクリエビルダーを使用してOR条件をAND条件でつなぐSQL文を作る方法
CakePHP4のController内でViewテンプレート、レイアウトの変更設定を記述する方法
CakePHP4から外部のデータベースにアクセスする方法解説
CakePHP4の数値項目は「like %10%」の部分一致検索(find select)はできない
CakePHP4でロギングスコープやログレベルを使用してログを出し分ける方法を解説
CakePHP2、CakePHP3、CakePHP4、CakePHP5のバージョンを調べる 2つの方法
Windows上のXAMPP環境のCakePHPのコマンド実行時に環境変数を指定する方法
CakePHP4で複数の引数(パラメータ)を付与してコマンドを実行する方法
その他の「CakePHP4」に関する記事一覧
GoogleAdwords
GoogleAdwords
この記事が参考になったと思いましたらソーシャルメディアで共有していただけると嬉しいです!
関連記事
-
CakePHP3で静的ページの作成は webrootか pagesを使う。トップページを参考に解説
CakePHP3で静的なページを設置する場合の方法(webrootとpagesとを活用する方法)を解説。pagesの解説はデフォルトのトップページがどう表示されているかを参考に解説。ルーティングの機能も。
-
CakePHP 2.3 連携先のテーブルの項目で条件抽出する場合
アソシエーション(連携)している先のテーブルの項目で条件抽出する際の考え方と注意点をサンプルソースを用いて説明しています。
-
CakePHP4でロギングスコープやログレベルを使用してログを出し分ける方法を解説
CakePHPのログ出力方法の解説。app.phpにログ設定をし、スコープやレベルを指定してログ出力を振り分ける方法、CakePHP4で配列出力にはvar_exportが必要なことなどを解説。
-
CakePHP3のアソシエーション機能を使い関連レコードをまとめて削除
CakePHP3でレコードを削除する際に関連するレコードをまとめて削除する機能の解説。フレームワークのメリットを存分に発揮し、コマンドを1行追加するだけで実装可能。
-
CakePHP3の更新画面でUpload Plugin 3.0を使う方法、viewで使う方法解説・その3
CakePHP3でファイル、画像をアップロードするプラグイン、upload plugin 3を導入する手順を解説した記事。3部作のその3で記事を更新する際のファイルの取り回しなどについてを解説。
-
CakePHP4のCakeDC/Usersのログイン時のリダイレクトとユーザ権限管理の設定解説
CakeDC謹製UsersプラグインのCakePHP4版の紹介。ログイン認証後にリダイレクトする先の設定方法についての解説と実運用するために必要なコツを解説。便利な仕組みも仕様の理解があって初めてうまく使いこなせる。
-
CakePHP3でパンくずの指定は HTMLヘルパーを使って指定する方法を解説
CakePHP3でパンくずの指定方法の解説。2つのヘルパーがあるが簡単なHTMLヘルパーを使った方法を、実際の状況に合わせて3つのパターン(エレメント化、ブロック化)にして解説。
-
CakePHP3のタイムゾーンを協定世界時UTCから日本標準時間JSTにずれを変更する方法
CakePHP3の標準設定のタイムゾーンは「UTC(協定世界時)」に設定されている。これを日本標準時に変更する方法(app.php、bootstrap.phpの変更方法)の解説。
-
CakePHP3ログファイルへの出力・$this->log()、独自ログへの出力方法の解説
コントロール、モデルの変数の中身を見るときはログに出力する方法が有効です。$this->log()を利用すると変数だけじゃなく、連想配列、オブジェクトも簡単にログ出力ができます。
-
CakePHP3にデザインテンプレートBootstrapを導入する方法・friendsofcake/bootstrap-ui使用
CakePHP3にプラグイン「friendsofcake/bootstrap-ui」、デザインテンプレート「Bootstrap」を設置する手順を解説。Bootstrapの簡単な使い方やデフォルトのデザインとの混在方法なども解説。