前の記事で、Responseマクロを定義することでテンプレートファイルのパスを動的に変更してテーマ機能を実装する方法を紹介しました:laravelはテンプレートテーマ機能を実装します, しかし、後でこの方法には欠点があることがわかり、テンプレートで @extends を使用する場合は、テンプレートのパスを明示的に指定する必要があるため、サブジェクトを完全に分離する必要があると考えました。存在しない場合は、存在しないので、他のテーマで代替テンプレートを自動的に検索しません。
応答マクロを定義する元の方法も実装できますが、より標準化された方法を使用することにしました。
laravel の View クラスには View::addNamespace メソッドがあります。このメソッドは、Laravel マニュアルの「拡張パックの開発」セクションで説明されています。このメソッドの説明はわかりにくいと言わざるを得ません。はい、最初にこの方法については触れません。
laravelレンダリングビューを記述する方法があります:
コードをコピーします コードは次のとおりです:
View::make('namespace::path');
//例: View::make('default::index.index');
名前空間を定義する方法は次の方法です:
コードをコピーします コードは次のとおりです:
View::addNamespace('default',app_path().'/views/default');
賢い友人なら、この機能が次のようなテンプレートのテーマ設定に役立つとすでに感じているかもしれません:
コードをコピーします コードは次のとおりです:
//青色のテーマを登録します
View::addNamespace('blue',app_path().'/views/blue');
//赤のテーマを登録します
View::addNamespace('red',app_path().'/views/red');
//緑のテーマを登録します
View::addNamespace('green',app_path().'/views/green');
の後に電話をかける:
コードをコピーします コードは次のとおりです:
//index.index テンプレートを緑のテーマでレンダリングします
View::make('green::index.index');
ただし、事前に View::addNamespace メソッドを通じてこれらのテーマのパス マッピングを登録する必要があり、レンダリング時に名前空間を明示的に指定する必要があります。
View でデフォルトの名前空間を設定できないと思いますか?この方法では、一度設定するだけで済みます。例:
コードをコピーします コードは次のとおりです:
// これは __construct で書くことができます
View::setDefaultNamespace('blue',app_path().'/views/blue');
コードをコピーします コードは次のとおりです:
//実際には View::make('blue::index.index');
と同等
View::make('index.index');
コードをコピーします コードは次のとおりです:
//設定がデータベースから読み取られると仮定し、オプションはモデルクラスです
$theme = Option::getByKey('theme');
View::setDefaultNamespace($theme,app_path().'/views/'.$theme);
しかし、残念ながら、View には setDefaultNamespace メソッドがないため、laravel 専用のコア クラス ライブラリを拡張するプロジェクトを作成することにしました。この関数は、src/Keepeye/Laravel でプロジェクトを表示できます。 /見る/ 使い方を確認してください。
さて、ここではlaravelテンプレートのテーマ関数の実装について説明しました。気に入っていただければ幸いです。