# Templates with Plates ## Template To separate HTML code and PHP code it's possible to use **templates** with markers for variable substitution. Variables are created in the PHP code and are passed to the template in the **rendering** phase. The server transmits only the `index.php` file to the user. The php file renders the templates as needed. ```html <?= $this->e($title)?> section('content')?> ``` ## [Plates](https://platesphp.com/) Plates is a template engine for PHP. A template engine permits to separate the PHP code (business logic) from the HTML pages. Installation through composer: `composer require league/plates`. ```php # index.php require "vendor/autoload.php"; use League\Plates\Engine; $templates = new Engine("path\\to\\templates"); echo $templates->render("template_name", [ "key_1" => "value_1", "key_2" => "value_2" ]); ``` ```php # template.php <?= $key_1?>

Hello

``` Variables in the template are created through an associative array `key => value`. The key (`"key"`) becomes a variable (`$key`) in the template. ### Layout It's possible to create a layout (a model) for a group of pages to make that identical save for the contents. In a layout it's possible to create a section called **content** that identifies content that can be specified at runtime. > **Note**: Since only the template has the data passed eventual loops have to be done there. ```php # index.php require 'vendor/autoload.php'; use League\Plates\Engine; $template = new Engine('/path/to/templates'); echo $template->render('template_name', [ "marker" => value, ... ]); ``` ```php # template.php # set the layout used for this template layout("layout_name", ["marker" => value, ...]) ?> # pass values to the layout # section contents

e($marker) ?>

``` ```php # layout.php <?= $marker ?> section('content')?> # insert the section ``` ### Escape It's necessary to verify that the output is in the necessary format. Plates offers `$this->escape()` or `$this->e()` to validate the output. In general the output validation allows to prevent [Cross-Site Scripting][owasp-xss] (XSS). [owasp-xss]: https://owasp.org/www-community/attacks/xss/ ### Folders ```php # index.php $templates->addFolder("alias", "path/to/template/folder"); # add a template folder echo $templates->render("folder::template"); # use a template in a specific folder ``` ### Insert It's possible to inject templates in a layout or template. It is done by using the `insert()` function. ```php # layout.php <?=$this->e($title)?> insert('template::header') ?> # insert template section('content')?> # page contents insert('template::footer') ?> # insert template ``` ### Sections It's possible to insert page contest from another template with the `section()` function. The content to be inserted must be surrounded with by the `start()` and `stop()` functions. ```php # template.php start("section_name") ?> # start section # section contents (HTML) stop() ?> # stop section # append to section is existing, create if not push("section_name") ?> # section contents (HTML) end() ?> ```