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 将为您提供以下输出。

Element Example