我可以在一个独立的项目中使用twig模板引擎,例如在1000 html页面上设计更多,即站点已满静态页面,如果你有任何简单的例子,我会感谢你
Wil*_*ell 10
我发现此Sitepoint教程非常简单。我已经简化并总结了步骤:
它假定您具有基本的命令行和Composer知识。
安装Twig-Composer 对大多数人来说可能是最简单的方法。composer require twig/twig在您的docroot中运行。这将创建一个composer.json(composer.lock如果您还没有的话)和一个vendor目录,Composer将在其中下载Twig及其使用的一些Symfony依赖项。Composer还将生成一些自动加载文件。
templates为您的Twig源文件创建一个目录(出于个人安全考虑,我个人喜欢将此目录放在docroot之上)
index.html.twig在该目录中创建样本模板bootstrap.php文件(几行PHP来加载和初始化Twig(并告诉它在哪里可以找到模板)index.php文件来演示加载和解析模板。这个:
在浏览器中访问第二个PHP文件,您将获得一个渲染的Twig模板。
boostrap.php:
<?php
// Load our autoloader
require_once __DIR__.'/vendor/autoload.php';
// Specify our Twig templates location
$loader = new Twig_Loader_Filesystem(__DIR__.'/../templates');
// Instantiate our Twig
$twig = new Twig_Environment($loader);
Run Code Online (Sandbox Code Playgroud)
index.php:
<?php
require_once __DIR__.'/bootstrap.php';
// Sample data
$foo = [
[ 'name' => 'Alice' ],
[ 'name' => 'Bob' ],
[ 'name' => 'Eve' ],
];
// Render our view
echo $twig->render('index.html', ['foo' => $foo] );
Run Code Online (Sandbox Code Playgroud)
templates / index.html.twig:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Twig Example</title>
</head>
<body>
<ul>
{% for item in foo %}
<li>{{ item.name }}</li>
{% endfor %}
</ul>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
下一步是将index.php修改为适当的“前端控制器”,以便它可以处理多个模板。
本教程还提到了诸如缓存生成的模板之类的内容。
我今天确实打架试图找出它是如何工作的,因为官方文档并不完美......所以我找到了解决方案。
结构简单:
twig/app/app.php
twig/vendor(在文档中使用 composer 创建) twig/views/page.html.twig
应用程序.php :
<?php require_once '../vendor/autoload.php';
use Twig\Loader\FilesystemLoader;
use Twig\Environment;
$loader = new FilesystemLoader('../views/');
$twig = new Environment($loader);
echo $twig->render('page.html.twig', ['text' => 'Fabien']);
Run Code Online (Sandbox Code Playgroud)
page.html.twig :
<h1>Hello {{ text }}</h1>
Run Code Online (Sandbox Code Playgroud)