网页的某些部分在多个网页上重复,但位于不同的位置。 CakePHP可以帮助我们重用这些重复的部分。这些可重复使用的部分称为元素 - 帮助框、额外菜单、等。元素基本上是一个迷你视图。我们还可以在元素中传递变量。
Cake\View\View::element(string $elementPath, array $data, array $options =[]
上述函数有以下三个参数 -
第一个参数是 /src/Template/element/ 文件夹中模板文件的名称。
第二个参数是可供渲染视图使用的数据数组。
第三个参数用于选项数组。例如缓存。
三个参数中,第一个是必填的,其余是可选的。
在 src/Template/element 目录中创建一个名为 helloworld.php 的元素文件。 将以下代码复制到该文件中。
<p>Hello World</p>
在src/Template处创建一个文件夹Elems,并在该目录下创建一个名为index.php的View文件。将以下代码复制到该文件中。
Element Example: <?php echo $this->element('helloworld'); ?>
在 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 文件。 将以下代码复制到控制器文件中。
<?php namespace App\Controller; use App\Controller\AppController; class ElemsController extends AppController{ public function index(){ } } ?>
通过访问以下 URL http://localhost/cakephp4/element-example
执行上面的示例执行后,上面的 URL 将给出以下输出。
以上是CakePHP 视图元素的详细内容。更多信息请关注PHP中文网其他相关文章!