sfw2/render
最新稳定版本:1.0.1
Composer 安装命令:
composer require sfw2/render
包简介
simple redering library for rendering response content on conditions (Content negotiation)
关键字:
README 文档
README
Enables redering web-content on condition (see https://developer.mozilla.org/en-US/docs/Web/HTTP/Content_negotiation for further information)
How to use it
First, set up a render-object and specify the conditions:
use Handlebars\Handlebars; use SFW2\Render\Conditions\IsAjaxRequest; use SFW2\Render\Conditions\MatchesPath; use SFW2\Render\RenderJson; use SFW2\Render\RenderOnConditions; // Have a look at salesforce/handlebars-php for the proper use $handlebars = new Handlebars([ "loader" => StringLoader(), ]); $render = new RenderOnConditions(); // Checks, if "X-Requested-With" header line is set and, if so, render data in json-format $render->addEngine(new IsAjaxRequest(), new RenderJson()); // Checks, if certain request-path is set and, if so, render data in xml-format. $render->addEngine(new MatchesPath('/'), new RenderJson($handlebars)); // Render other stuff in html-format $render->addEngine(new AlwaysTrue(), new RenderHtml($handlebars, '<html>{{content}}</html>'));
use the prebuild render in your controller/action-class to render your response-content on the previous declared conditions
use Psr\Http\Message\RequestInterface; use Psr\Http\Message\ResponseInterface; use SFW2\Render\RenderInterface; class MyController{ public function __construct( private RenderInterface $render ) { } public function myAction(RequestInterface $request, ResponseInterface $response, array $data): ResponseInterface { return $this->render->render($request, $response, [], 'mytemplate.handlebars'); } }
统计信息
- 总下载量: 15
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: AGPL-3.0-or-later
- 更新时间: 2025-02-08