首页  >  文章  >  后端开发  >  CakePHP 视图元素

CakePHP 视图元素

王林
王林原创
2024-09-10 17:22:29571浏览

网页的某些部分在多个网页上重复,但位于不同的位置。 CakePHP可以帮助我们重用这些重复的部分。这些可重复使用的部分称为元素 - 帮助框、额外菜单、等。元素基本上是一个迷你视图。我们还可以在元素中传递变量。

Cake\View\View::element(string $elementPath, array $data, array $options =[]

上述函数有以下三个参数 -

  • 第一个参数是 /src/Template/element/ 文件夹中模板文件的名称。

  • 第二个参数是可供渲染视图使用的数据数组。

  • 第三个参数用于选项数组。例如缓存。

三个参数中,第一个是必填的,其余是可选的。

示例

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

Element Example: <?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

以上是CakePHP 视图元素的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn