我正在使用以下代码渲染原型:
{{form_widget(form.get('prototype').myField, {'attr': {'value': '<%= myModelProperty %>'} }) }}
BackboneJS应该读取这个 twig 块生成的代码,并将 <%= myModelProperty %> 替换为一些模型属性值。
这不会发生,因为该值在 twig 中被转义,因此被替换为:
<%= viewport %>
我试图在 *form_div_layout.html* 文件中将值强制为 RAW:
> {% block field_widget %} {% spaceless %}
> {% set type = type|default('text') %}
> <input type="{{ type }}" {{ block('widget_attributes') }} {% if value is not empty %}value="{{ value|raw }}" {% endif %}/> {%
> endspaceless %} {% endblock field_widget %}
但没有成功。
所以我的问题是如何不逃避树枝中的字段值。
谢谢!
编辑
解决方案:所以实际上方法是正确的,我必须使用“原始”过滤器来使我的变量不被转义。我有一个自动转义块集,可以包含这个特定的输出,这就是为什么它必须“未转义”的原因。
Symfony 2 的 Twig 包提供了几个块来渲染表单数据,这些块使用一个特定的块来进行属性渲染,称为“{% block widget_attributes %}”。
我所做的是编辑这个块(我有一个包含所有自定义块的单独模板文件),所以我可以添加一层“是否应该转义这个值”:
{% block widget_attributes %}
{% spaceless %}
id="{{ id }}" name="{{ full_name }}"{% if read_only %} disabled="disabled"{% endif %}{% if required %} required="required"{% endif %}{% if max_length %} maxlength="{{ max_length }}"{% endif %}{% if pattern %} pattern="{{ pattern }}"{% endif %}
{% for attrname,attrvalue in attr %}
{# Attribute value can be defined as an array. ['data']: contains the actual value, ['escape']: boolean (true if the value HAS to be escaped)#}
{% if attrvalue.data is defined %}
{% if not attrvalue.escape %}
{{attrname}}="{{ attrvalue.data|raw }}"
{% else %}
{{attrname}}="{{ attrvalue.data|e }}"
{% endif %}
{% else %}
{{attrname}}="{{attrvalue}}"
{% endif %}
{% endfor %}
{% endspaceless %}
{% endblock widget_attributes %}
从我的树枝文件中调用:
{{ form_widget(form.displays.get('prototype').myField, {'attr': {'value': { 'data': myvalue, 'escape': false } } }) }}
转义是在 {{ }} twig 标签中打印值时完成的,所以我之前所做的是将未转义的值发送到实际调用 print 并且值因此被转义的块。
这对我有用!谢谢!