CakePHP - Estendendo Visualizações

Muitas vezes, ao fazer páginas da web, queremos repetir certas partes das páginas em outras páginas. O CakePHP tem a facilidade de estender a visualização em outra visualização e, para isso, não precisamos repetir o código novamente.

o extend() método é usado para estender as vistas em ViewArquivo. Este método recebe um argumento, ou seja, o nome do arquivo de visualização com o caminho. Não use a extensão .ctp ao fornecer o nome do arquivo de visualização.

Exemplo

Faça alterações no arquivo config / routes.php conforme mostrado no programa a seguir.

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('extend',['controller'=>'Extends','action'=>'index']);
   $builder->fallbacks();
});

Criar um ExtendsController.php arquivo em src/Controller/ExtendsController.php. Copie o código a seguir no arquivo do controlador.

src / Controller / ExtendsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   class ExtendsController extends AppController{
      public function index(){
      }
   }
?>

Crie um diretório Extends em src/Template e nessa pasta crie um Viewarquivo chamado header.php. Copie o código a seguir nesse arquivo.

src / Template / Extends / header.php

<div align="center">
   <h1>Common Header</h1>
</div>
<?= $this->fetch('content') ?>

Crie outro View sob Extends diretório chamado index.php.Copie o código a seguir nesse arquivo. Aqui, estamos estendendo a visão acimaheader.php.

src / Template / Extends / index.php

<?php $this->extend('header'); ?>
This is an example of extending view.

Execute o exemplo acima visitando a seguinte URL http: // localhost / cakephp4 / extend

Resultado

Após a execução, você receberá a seguinte saída.