PHP中使用Twig渲染视图核心三步:安装Twig(推荐Composer)、创建.html.twig模板、PHP中用FilesystemLoader和Environment加载渲染;支持缓存、模板继承与自动转义,轻量灵活且安全。

PHP 中使用 Twig 渲染视图,核心就三步:安装 Twig、创建模板文件、在 PHP 中加载并渲染。它不依赖框架,轻量灵活,适合从原生 PHP 到 Laravel、Symfony 各种场景。
安装 Twig(推荐 Composer 方式)
在项目根目录执行:
composer require twig/twig
安装完成后,自动注册了自动加载机制。你无需手动 require 或 include Twig 类文件,直接 new 即可使用。
- 确保 PHP 版本 ≥ 7.2.5(Twig v3 要求)
- 如用旧版 PHP,可指定安装 Twig v2:
composer require "twig/twig:^2.15" - 开发环境建议开启 Twig 的缓存(生产环境更必须),避免每次请求都重新编译模板
准备模板文件(.html.twig 后缀)
新建 templates/ 目录,放你的模板,例如:
templates/home.html.twig
内容示例:
立即学习“PHP免费学习笔记(深入)”;
{% set title = ‘欢迎页’ %}
{{ title }}
当前时间:{{ now|date(‘Y-m-d H:i:s’) }}
Twig 语法简洁:双大括号输出变量,{% %} 写逻辑(如 if、for、set),管道符 | 接过滤器(如 date、upper)。
PHP 中加载并渲染模板
基础代码如下(放在 index.php 或控制器中):
require_once ‘vendor/autoload.php’;
use Twig/Environment;
use Twig/Loader/FilesystemLoader;
// 1. 指定模板存放路径
$loader = new FilesystemLoader(‘templates’);
// 2. 创建 Twig 环境(启用缓存提升性能)
$twig = new Environment($loader, [
‘cache’ => __DIR__ . ‘/var/cache/twig’, // 缓存目录需可写
]);
// 3. 渲染模板并输出
echo $twig->render(‘home.html.twig’, [
‘name’ => ‘张三’,
‘items’ => [‘苹果‘, ‘香蕉’, ‘橙子’]
]);
-
render()第二个参数是传给模板的变量数组,模板里用{{ name }}或{% for item in items %}就能访问 - 缓存目录(如
/var/cache/twig)首次运行会自动生成,务必保证 Web 服务器有写权限 - 开发时可临时关闭缓存:
'cache' => false,方便实时看到模板修改效果
常见小技巧与注意点
- 模板继承用
{% extends 'base.html.twig' %}+{% block content %}{% endblock %}实现布局复用 - 引入子模板用
{% include 'header.html.twig' %},适合组件化拆分 - 避免在模板里写复杂 PHP 逻辑——Twig 设计哲学是“逻辑与展示分离”,业务处理应在 PHP 层完成
- 输出用户数据前,默认已自动转义 HTML(防 XSS),如需原样输出加
|raw过滤器,但要确保内容可信
基本上就这些。Twig 上手快,语法干净,扩展性强,配合适当的缓存和目录结构,能让你的 PHP 视图层既安全又易维护。
以上就是PHP Twig模板引擎入门指南_PHP使用Twig渲染视图流程的详细内容,更多请关注php中文网其它相关文章!


