ElP*_*ter 3 javascript symfony twig
使用带有twig模板的symfony2,我通常使用嵌入在*html.twig文件中的js 来对页面进行dinamize.
如果我的页面附加了外部JS文件怎么办?我怎么能在它们中引入twig代码?
我知道这听起来有些磨损,但尝试从javascript重定向到已知的symfony路径时并没有那么多.像这样:
$.post("{{ path('_check_coupon') }}",{code: coupon_code}, function(json) {
// do whatever...
});
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,我在一个完全分离的js文件中有一个对已知路径的ajax调用"_check_coupon".
任何想法接近这个?
提前致谢
您可以data-path在DOM元素的属性中嵌入此类路径,例如:
<div id="widget" data-path="{{ path('_check_coupon') }}"> ... </div>
Run Code Online (Sandbox Code Playgroud)
然后只需获取它:
$.post( $('#widget').data('path') ,{code: coupon_code}, function(json) {
// do whatever...
});
Run Code Online (Sandbox Code Playgroud)
这是一种普通的方法,但更可维护的是将js和twig混合在一个文件中 - 至少你不会得到语法高亮.
当然,如果您正在处理表单,只需获取表单的action属性.
无论如何,我建议你不要在同一页面上同时使用JS和标记:你将无法缓存脚本,也不能缩小它们,所以考虑将它们分离,除非涉及的线路非常少.随意检查我的小图书馆.