Documentação do Symfony - versão 3.4
Renderizada do repositório symfony-docs-pt-BR no Github

Como renderizar um template sem um Controlador personalizado

Normalmente, quando você precisa criar uma página, você cria um controlador e renderiza um template a partir deste controlador. Mas se você estiver renderizando um template simples que não precisa de quaisquer dados passados ​​para ele, pode-se evitar totalmente a criação do controlador, usando o controlador incorporado FrameworkBundle:Template:template .

Por exemplo, suponha que você queira renderizar um template static/privacy.html.twig, que não requer que quaisquer variáveis ​​sejam passadas ​​a ele. Você pode fazer isso sem criar um controlador:

  • YAML
    1
    2
    3
    4
    5
    acme_privacy:
        path: /privacy
        defaults:
            _controller: FrameworkBundle:Template:template
            template:    static/privacy.html.twig
    
  • XML
     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    <?xml version="1.0" encoding="UTF-8" ?>
    
    <routes xmlns="http://symfony.com/schema/routing"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://symfony.com/schema/routing http://symfony.com/schema/routing/routing-1.0.xsd">
    
        <route id="acme_privacy" path="/privacy">
            <default key="_controller">FrameworkBundle:Template:template</default>
            <default key="template">static/privacy.html.twig</default>
        </route>
    </routes>
    
  • PHP
     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    use Symfony\Component\Routing\RouteCollection;
    use Symfony\Component\Routing\Route;
    
    $collection = new RouteCollection();
    $collection->add('acme_privacy', new Route('/privacy', array(
        '_controller'  => 'FrameworkBundle:Template:template',
        'template'     => 'static/privacy.html.twig',
    )));
    
    return $collection;
    

O controlador FrameworkBundle:Template:template irá simplesmente renderizar qualquer template que você passar como o valor padrão template.

Naturalmente, você também pode usar esse truque ao renderizar controladores embutidos a partir de um template. Mas, uma vez que a finalidade de renderizar um controlador a partir de um template é tipicamente para preparar alguns dados num controlador personalizado, isso provavelmente só é útil se você gostaria de armazenar em cache esta página parcial (veja Armazenar em cache o Template estático).

  • Twig
    1
    {{ render(url('acme_privacy')) }}
    
  • PHP
    1
    2
    3
    <?php echo $view['actions']->render(
        $view['router']->generate('acme_privacy', array(), true)
    ) ?>
    

Armazenar em cache o Template estático

Uma vez que os templates renderizados dessa forma são tipicamente estáticos, pode fazer sentido armazená-los em cache. Felizmente, isso é fácil! Configurando algumas outras variáveis ​​em sua rota, você pode controlar exatamente como a página é armazenada em cache:

  • YAML
    1
    2
    3
    4
    5
    6
    7
    acme_privacy:
        path: /privacy
        defaults:
            _controller:  FrameworkBundle:Template:template
            template:     'static/privacy.html.twig'
            maxAge:       86400
            sharedAge:    86400
    
  • XML
     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    13
    <?xml version="1.0" encoding="UTF-8" ?>
    
    <routes xmlns="http://symfony.com/schema/routing"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://symfony.com/schema/routing http://symfony.com/schema/routing/routing-1.0.xsd">
    
        <route id="acme_privacy" path="/privacy">
            <default key="_controller">FrameworkBundle:Template:template</default>
            <default key="template">static/privacy.html.twig</default>
            <default key="maxAge">86400</default>
            <default key="sharedAge">86400</default>
        </route>
    </routes>
    
  • PHP
     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    use Symfony\Component\Routing\RouteCollection;
    use Symfony\Component\Routing\Route;
    
    $collection = new RouteCollection();
    $collection->add('acme_privacy', new Route('/privacy', array(
        '_controller'  => 'FrameworkBundle:Template:template',
        'template'     => 'static/privacy.html.twig',
        'maxAge'       => 86400,
        'sharedAge' => 86400,
    )));
    
    return $collection;
    

Os valores maxAge e sharedAge são usados ​​para modificar o objeto Response criado no controlador. Para mais informações sobre cache, consulte /book/http_cache.

Há também uma variável private (não mostrada aqui). Por padrão, o Response será tornado público enquanto maxAge ou sharedAge são passados. Se definida como true, o Response será marcado como privado.