5

我想创建可以自己打印一些html代码的视图,同时将javascript代码发送到底部,而不扩展布局

这个想法是我有一个布局,然后当前 url 的特定视图扩展了该布局,并且在该视图中,我包含其他视图,这些视图具有将代码添加到超出范围的其他块的能力(因为它们不'不继承布局或继承自它的视图)。那可能吗?

假设这是我的布局的一部分:

{# ::layout.html.twig #}
.
.
{% block javascripts %}
{% endblock %}
</body>
.
.

这是我的观点:

{# Company:Bundle:about.html.twig #}
{% extends '::layout.html.twig' %}
.
.
{% include 'Company:buttons:google_button.html.twig' %}
.
.

这是我想要包含的视图,例如,一个 google +1 按钮:

{# Company:buttons:google_button.html.twig #}
<gb></gb> {# or whatever #}

{# somehow send '<script>blabla</script>' to the 'javascripts' block #}

可以用 twig 和 symfony2 做这样的事情吗?

4

3 回答 3

2

我想你必须编写自己的 Twig 扩展来定义两个函数,比如说add_jsprint_js

树枝扩展:

namespace Me\MyBundle\Twig\Extension;

class MyExtension extends \Twig_Extension {
    private $js = array();

    /**
     * {@inheritdoc}
     */
    public function getFunctions() {
        return array(
            'put_js' => new \Twig_Function_Method($this, 'putJs', array('is_safe' => array('html'))),
            'print_js' => new \Twig_Function_Method($this, 'printJs', array('is_safe' => array('html')))
        );
    }

    public function putJs($js) {
        $this->js[] = $js;
    }

    public function printJs() {
        return implode(PHP_EOL, $this->js);
    }

    /**
     * Returns the name of the extension.
     *
     * @return string The extension name
     */
    public function getName() {
        return 'my';
    }
}

依赖注入配置:

<service id="twig.extension.me.my" class="Me\MyBundle\Twig\Extension\MyExtension" public="false">
    <tag name="twig.extension" />
</service>

最终用法:

{# ::layout.html.twig #}

   ...
   {{ print_js() }}
</body>

{# Company:buttons:google_button.html.twig #}

{% put_js('<script>...</script>') %}
于 2011-06-30T15:16:55.110 回答
2

只是想实现一个包含来自@Crozin 的代码的包,但在packagist.org上我发现了一个已经完成的包:

资产管理包

于 2013-03-04T22:00:08.713 回答
1

我刚刚使用“使用”实现了您面临的确切问题:http: //twig.sensiolabs.org/doc/tags/use.html

需要进行一些重构,因为您需要从主基本文件中删除 javascript 块并将其再次包含在 javascript twig 文件中。然后在您的视图中,您可以通过首先定义来访问 javascript 块:

{% use 'ExampleBundle::javascript.html.twig' with javascript' %}

于 2011-11-02T15:33:27.183 回答