經過一番調查後,我發現雖然翻譯編譯過濾器是幾個月前在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'})
該問題似乎與TwigJs \ JsCompiler :: getDefine('locale')返回null有關。我似乎無法找到它的配置。 – 2012-03-08 19:22:35