微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – Twigjs和动态翻译

我遇到了一个问题,我使用Symfony2 twigjs和assetic动态渲染我的一些模板.

我已经阅读了文档,源代码和测试.

在TransFilterCompilerTest.PHP / testCompileDynamicTranslations中它似乎是一个

{{‘foo’|在我的树枝模板中转换}}

将在twigjs模板中替换

‘this.env_.filter(“trans”,’…在我的twigjs中

但在我编译的js中我只有sb.append(twig.filter.escape(this.env_,“posted”,“html”,null,true));

你知道为什么吗?

谢谢!

解决方法:

经过一番调查后,我发现虽然几个月前在JMSTwigJsBundle中添加了翻译编译过滤器,但最近才向Assetic添加了所需的功能.使用已发布的库版本将无法正常工作.目前,必须使用git的master.

使用deps文件

[assetic]
    git=http://github.com/kriswallsmith/assetic.git

[AsseticBundle]
    git=http://github.com/symfony/AsseticBundle.git
    target=/bundles/Symfony/Bundle/AsseticBundle

必须将站点支持的语言指定为参数.我将它添加到我的config.yml文件中.

parameters:
    assetic.variables:
        locale: ['en', 'fr']

最后,文件集必须表明它根据语言环境而变化.

{% javascripts vars=["locale"]
    '@AcmeBundle/Resources/views/Default/some_template.html.twig'
    filter="twig_js"
%}  

以下是完整性的示例模板:

{% twig_js name="some_template" %}
<b>{{'test.say.hello' | trans({"%name%": name|default("World")})}}</b>

还必须在模板定义之前加载twig.js引导程序文件.调用模板符合预期:

Twig.render(some_template, {name: 'CoBaLt2760'})

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐