使用 Twig 模板引擎可实现 php 业务逻辑与页面展示分离。通过 composer 安装 Twig 后,配置自动加载并创建 Twig 环境,设置模板目录与缓存选项;在 templates 中创建 html 模板文件,利用 {{}} 语法插入动态数据;通过 {% extends %} 和{% block %}实现模板 继承 ,统一页面布局,提升 代码复用 性与维护性。

如果您在开发 PHP 项目时希望将业务逻辑与页面展示分离,以提升代码可维护性,可以采用模板引擎来实现视图层的独立管理。以下是使用 Twig 模板引擎在 PHP 中实现视图分离的具体方法:
一、安装并引入 Twig 环境
通过 Composer工具 引入 Twig 库是标准做法,这能确保依赖被正确加载,并便于后续升级维护。
1、打开命令行 工具,进入项目根目录,执行以下命令安装 Twig:
composer require “twig/twig:^3.0”
立即学习“PHP 免费学习笔记(深入)”;
2、安装完成后,在入口文件或 配置文件 中引入自动加载机制:
require_once ‘vendor/autoload.php‘;
二、配置 Twig 实例
创建一个 Twig_Environment对象,用于定义模板存储路径和缓存设置,从而控制模板解析行为。
1、创建名为 templates 的目录用于存放 HTML 模板文件。
$loader = new TwigLoaderFilesystemLoader(‘templates’);
$twig = new TwigEnvironment($loader, [
‘cache’ => ‘cache’,
‘debug’ => true,
]);
注意:生产环境应启用缓存以提高性能,开发阶段建议开启 debug 模式以便排查错误
三、创建并使用模板文件
将 HTML 结构与动态数据解耦,通过变量占位符接收来自 PHP 的数据内容。
1、在 templates 目录下新建 index.html.twig 文件:
<h1> 欢迎 {{name}}</h1>
2、在主 PHP 文件中渲染该模板:
echo $twig->render(‘index.html.twig’, [‘name’ => ‘ 张三 ’]);
变量 {{name}} 会被传入的数组值替换,实现动态输出
四、使用模板继承与布局结构
通过定义基础模板,使多个页面共享相同的 HTML 框架,减少重复代码。
1、创建 base.html.twig 作为母版页:
<!DOCTYPE html>
<html>
<head><title>{% block title %}默认标题{% endblock %}</title></head>
<body>{% block content %}{% endblock %}</body>
</html>
2、在子模板中继承并填充区块:
{% extends “base.html.twig” %}
{% block title %}首页{% endblock %}
{% block content %}<p> 这是主页内容 </p>{% endblock %}


