如何在 SlimFramework v4 中添加 Twig-View



我正在尝试在苗条v4中添加树枝视图

在 slim v3 中,我们在容器中添加树枝视图

$container['view'] = function ($c) {
$view = new SlimViewsTwig('path/to/templates', [
'cache' => 'path/to/cache'
]);
// Instantiate and add Slim specific extension
$router = $c->get('router');
$uri = SlimHttpUri::createFromEnvironment(new SlimHttpEnvironment($_SERVER));
$view->addExtension(new SlimViewsTwigExtension($router, $uri));
return $view;
};

但我不能在苗条的 v4 中添加这样的树枝

更新 :Twig-View已达到稳定版本,文档已更新以解决Slim 4集成问题。
如果您仍在使用不稳定版本的 Twig-View,请考虑升级。

首先,您需要将 Twig-View 包添加到您的项目中:

composer require slim/twig-view

并假设以下目录结构:

composer.json
cache/
public/
|--index.php
templates/
|--hello.twig
vendor/
|--autoload.php

以下是两个工作示例:

如果您使用容器(根据 Slim 4 文档是可选的),您可以将 Tiwg 创建定义添加到容器并在需要时使用它。(我在此示例中使用的是php-di/php-di,但您可以使用任何与 PSR 兼容的依赖项容器。

index.php,使用容器

<?php
use DIContainer;
use SlimFactoryAppFactory;
use SlimViewsTwig;
use SlimViewsTwigMiddleware;
require  __DIR__ . '/../vendor/autoload.php';
// Create Container
$container = new Container();
AppFactory::setContainer($container);
// Set view in Container
$container->set('view', function() {
return Twig::create(__DIR__ . '/../templates',
['cache' => __DIR__ . '/../cache']);
});
// Create App
$app = AppFactory::create();
// Add Twig-View Middleware
$app->add(TwigMiddleware::createFromContainer($app));
// Example route
$app->get('/hello/{name}', function ($request, $response, $args) {
return $this->get('view')->render($response, 'hello.twig', [
'name' => $args['name']
]);
});
// Run the app
$app->run();

您也可以跳过容器创建,但在这种情况下,您需要先创建 Twig 实例,然后再尝试渲染模板。

index.php,不带容器

<?php
use SlimFactoryAppFactory;
use SlimViewsTwig;
use SlimViewsTwigMiddleware;
require __DIR__ . '/../vendor/autoload.php';
// Create App
$app = AppFactory::create();
// Create Twig
$twig = Twig::create(__DIR__ . '/../templates',
['cache' => __DIR__ . '/../cache']);
// Add Twig-View Middleware
$app->add(TwigMiddleware::create($app, $twig));
// Example route
// Please note how $view is created from the request
$app->get('/hello/{name}', function ($request, $response, $args) {
$view = Twig::fromRequest($request);
return $view->render($response, 'hello.twig', [
'name' => $args['name']
]);
});
// Run the app
$app->run();

你好.twig

Hello {{ name }}

现在尝试在浏览器中访问/hello/slim4,输出将是:

你好苗条4

SlimTwigView处于3.0.0测试版(至少截至2019年10月12日),有些事情已经发生了变化。我看到的几个在线教程以及官方文档不再有效。

TwigMiddleware 不再将 $container 的实例作为参数,因此您必须首先手动将 Twig 放在容器上,例如:

$container->set('view', function() {
// Of course put correct path to your views here
return new Twig('../views', ['cache' => false]);
});

然后,您可以使用类的新createFromContainer方法将TwigMiddleware添加到Slim App中,如下所示:

$app->add(TwigMiddleware::createFromContainer($app));
// which is equivalent to:
// $app->add(TwigMiddleware::createFromContainer($app, 'view'));

此时,您可以像这样渲染 Twig 视图:

$app->get('/', function (Request $request, Response $response, $args) {
return $this->get('view')->render($response, 'home.twig');
});

使用 Slim 特定中间件时,您现在可以访问其他 Twig 扩展:

url_for full_url_for is_current_url current_url get_uri

好吧!就我而言,我使用的是Slim 4.0和Twig ^2.5。我添加到代码中的所有内容都是

$container->set('view', function () use ($container) {
$view = new SlimViewsTwig( 
__DIR__ .'/Templates' 
, [ 'cache' => false   ]  //you can turn on caching by providing string path to cache or set to false
);  

return $view;
});

最新更新