使用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 %}


