sitepoint/templating-engine
最新稳定版本:v0.1.0
Composer 安装命令:
composer require sitepoint/templating-engine
包简介
A simple, easy to follow PHP templating engine
README 文档
README
A simple, easy to follow PHP templating engine. Designed to be forked, modified, extended and hacked.
Example Usage
This templating engine supports inheritance through blocks. Child templates declare blocks which can be overridden, extended and displayed by parent templates.
Child templates can declare a single parent template at any point using the parent() method which also provides the opportunity to modify the variables that are in scope.
All templates must follow the namespace::path/to/template format.
<?php $this->parent('app::layout', ['title' => 'Blog Post: '.$title]); ?> <?php $this->block('content', function ($params) { extract($params); ?> <article> <header> <h1><?=$this->escape($this->caps($title));?></h1> </header> <main> <?php foreach($paragraphs as $paragraph): ?> <p> <?=$this->escape($paragraph);?> </p> <?php endforeach; ?> </main> </article> <?php }); ?>
<html> <head> <title><?=$this->escape($title);?></title> </head> <body> <?=$this->block('content');?> </body> </html>
Namespaces and function callbacks are registered with the templating engine when it is constructed. Function callbacks are available as methods within the template context and must be callable.
The default template extension is phtml, but this can be overridden.
use SitePoint\TemplatingEngine\TemplatingEngine; $engine = new TemplatingEngine( ['app' => '/path/to/templates/app'], // The namespaces to register ['caps' => 'strtoupper'], // Function callbacks to register inside the template context 'phtml' // The extension of the templates (defaults to phtml) ); $params = [ 'title' => 'My Blog Post', 'paragraphs' => [ 'My first paragraph.', 'My second paragraph.', ], ]; echo $engine->render('app::post', $params);
Template Context Methods
The following methods are available by default within the template context.
/** * Define a parent template. * * @param string $template The name of the parent template. * @param array $params Parameters to add to the parent template context * * @throws EngineException If a parent template has already been defined. */ public function parent($template, array $params = []);
/** * Insert a template. * * @param string $template The name of the template. * @param array $params Parameters to add to the template context */ public function insert($template, array $params = []);
/** * Render a block. * * @param string $name The name of the block. */ public function block($name, callable $callback = null);
/** * Escape a string for safe output as HTML. * * @param string $raw The unescaped string. * * @return string The escaped HTML output. */ public function escape($raw);
Authors
Change Log
This project maintains a change log file
License
The MIT License (MIT). Please see LICENSE for more information.
统计信息
- 总下载量: 11
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 3
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-10-26