CakePHP - 视图元素
网页的某些部分会在多个网页上重复出现,但位置不同。CakePHP 可以帮助我们重用这些重复的部分。这些可重用的部分称为元素 - 帮助框、额外菜单等。元素基本上是一个迷你视图。我们还可以在元素中传递变量。
Cake\View\View::element(string $elementPath, array $data, array $options =[]
上述函数有三个参数,如下所示 −
第一个参数是 /src/Template/element/ 文件夹中模板文件的名称。
第二个参数是要提供给渲染视图的数据数组。
第三个参数是选项数组。例如缓存。
在这 3 个参数中,第一个是必需的,其余的是可选的。
示例
在以下位置创建一个元素文件src/Template/element 目录中名为 helloworld.php。将以下代码复制到该文件中。
src/Template/element/helloworld.php
<p>Hello World</p>
在 src/Template 创建一个文件夹 Elems,并在该目录下创建一个名为 index.php 的 View 文件。将以下代码复制到该文件中。
src/Template/Elems/index.php
元素示例:<?php echo $this->element('helloworld'); ?>
按照以下程序所示,对 config/routes.php 文件进行更改。
config/routes.php
<?php use Cake\Http\Middleware\CsrfProtectionMiddleware; use Cake\Routing\Route\DashedRoute; use Cake\Routing\RouteBuilder; $routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf'); $builder->connect('/element-example',['controller'=>'Elems','action'=>'index']); $builder->fallbacks(); });
在 src/Controller/ElemsController.php 创建一个 ElemsController.php 文件。将以下代码复制到控制器文件中。
src/Controller/ElemsController.php
<?php namespace App\Controller; use App\Controller\AppController; class ElemsController extends AppController{ public function index(){ } } ?>
通过访问以下 URL http://localhost/cakephp4/element-example 执行上述示例
输出
执行后,上述 URL 将为您提供以下输出。