有几种方法可以解决这个问题。
在相应的模块目录中创建布局文件
下面的示例显示了一些 subDomain 模块的规范目录结构,包括它的布局 (domain.php):
subDomain/
Module.php the module class file
controllers/ containing controller class files
HomeController.php the home controller class file
models/ containing model class files
views/ containing controller view and layout files
layouts/ containing layout view files
domain.php the domain layout file
home/ containing view files for HomeController
index.php the index view file
按照这个简单的结构,您可以在模块的控制器中按名称设置任何布局:
namespace myApp\modules\subDomain\controllers;
class HomeController extends Controller {
public function actionGetDomain() {
$this->layout = 'domain'; // equals 'myApp/modules/subDomain/views/layouts/domain'
}
}
这是最可取的方式,因为模块是独立的软件单元,由其自己的模型、布局、控制器等组成。
指定包含布局文件的目录的完整路径
在某些情况下,您可能希望使用位于模块目录之外的布局文件:
class HomeController extends Controller {
public function actionGetDomain() {
$this->layout = '@app/views/layouts/main';
}
}
其中@app是当前运行的应用程序的基本路径,例如:
myApp/frontend
在这种情况下,请确保 main.php 布局文件存在于以下目录中:
myApp/frontend/views/layouts/main.php