1

我正在尝试为我的项目创建一个 Twig 扩展。目标是使用 jquery.cluetip 插件生成一个用户弹出窗口,该插件可以在一个漂亮的工具提示中显示 AJAX 查询的结果。生成的 HTML 代码应如下所示:

<span class="userdata" rel="/profile/123/ajaxUserdata.html">W00d5t0ck</span>

目前,我的代码如下所示:

class UserDataSpanExtension extends \Twig_Extension
{                       
    protected $_securityContext;

    public function __construct(SecurityContextInterface $security)
    {
        $this->_securityContext = $security;
    }

    public function getFilters()
    {
        return array(
            'userdataspan' => new \Twig_Filter_Method($this, 'getUserDataSpan', array('is_safe' => array('html'))),
        );
    }

    public function getUserDataSpan(User $user)
    {
        if (!is_object($this->_securityContext->getToken()) || !is_object($this->_securityContext->getToken()->getUser()))
            return '<span class="userdata-secret" title="|User information|User information is available only to logged in users.">[not available]</span>';

        return '<span class="userdata" rel="">' . $user->getDisplayName() . '</span>';
    }

    public function getName()
    {
            return 'twig_userdataspan';
    }
}

现在我有点卡住了,因为我不知道应该如何填写我的rel属性。在 Twig 模板中,我会使用

{{ path('AcmeDemoBundle_ajaxUserdata', { id: user.id }) }}

但这在 Twig 扩展中不起作用。谁能指出一个可用的例子?

4

1 回答 1

4

在您的树枝扩展服务中注入并router在您的方法中以通常的方式生成 url,例如

$this->router->generate('AcmeDemoBundle_ajaxUserdata', array(
    'id' => $user->id,
));

在 services.yml 中将 @router 参数添加到您的扩展:

services:
    demo.twig.extension:
        class: DemoBundle\Twig\Extension
        arguments: [@router]
于 2012-07-31T23:07:28.357 回答