承接 setono/php-templates 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

setono/php-templates

最新稳定版本:v1.2.0

Composer 安装命令:

composer require setono/php-templates

包简介

An extremely simple, yet wonderful, php template system

README 文档

README

Latest Version Latest Unstable Version Software License Build Status Coverage Status Quality Score

In the PHP world we have wonderful template engines/systems like Twig and Plates. If you need features like inheritance, extensions, built-in helpers etc. you should go with one of those.

On the other hand, if you just want to be able to create a PHP template like this:

<h1>Hello <?=$name?></h1>
<p>Today's date is <?=$date->format('d.m.Y')?></p>

Then this library is for you.

Installation

$ composer require setono/php-templates

Usage

In this example I assume your templates are here: templates/php and you have a template like this:

<!-- templates/php/App/hello.php -->
<h1>Hello <?=$name?></h1>

The path of this template is divided into three parts: templates/php is the path added to the engine. App is the namespace. hello is the template name.

Keep this in mind when looking at the rendering of this template:

<?php
// render.php

use Setono\PhpTemplates\Engine\Engine;

$engine = new Engine();
$engine->addPath('templates/php');

echo $engine->render('@App/hello', [
    'name' => 'John Doe',
]);

This will output:

<h1>Hello John Doe</h1>

Override templates

If you want to override templates, it is very straight forward. Let's set up the engine first:

<?php
// override.php

use Setono\PhpTemplates\Engine\Engine;

$engine = new Engine();
$engine->addPath('vendor/namespace/src/templates/php'); // The path is added with a default priority of 0
$engine->addPath('templates/php', 10); // Here we set the priority higher than the vendor added path

Here is the template we want to override:

<!-- vendor/namespace/src/templates/php/ThirdPartyNamespace/hello.php -->
<h1>Hi <?=$name?>! This template is not rendered, since it is overridden</h1>

And here is the template that will override the previous one:

<!-- templates/php/ThirdPartyNamespace/hello.php -->
<h1>Hi <?=$name?>! This template is rendered, yeah!</h1>

Notice that we override templates by adding a directory with the same name as the original directory. In this case: ThirdPartyNamespace.

<?php
echo $engine->render('@ThirdPartyNamespace/hello', [
    'name' => 'John Doe',
]);

This will output:

<h1>Hi John Doe! This template is rendered, yeah!</h1>

统计信息

  • 总下载量: 2.6k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 0
  • 依赖项目数: 3
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-05-06

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固