PHP Twig模板引擎入门指南_PHP使用Twig渲染视图流程

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

php twig模板引擎入门指南_php使用twig渲染视图流程

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免费学习笔记(深入)”;


逻辑智能

逻辑智能

InsiderX:打造每个团队都能轻松定制的智能体员工

逻辑智能
145


查看详情
逻辑智能

{% 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中文网其它相关文章!

https://www.php.cn/faq/1834685.html

发表回复

Your email address will not be published. Required fields are marked *