我正在学习Symfony2。目前,我正在尝试在树枝模板中呈现表单标签。标签包含一个html标记,在我的twig文件中无法正确呈现。
下面是创建表单字段的代码段:
$builder->add('zipcode', 'integer', array(
'label' => '<abbr title="Zone Improvement Plan">CAP</abbr> code',
));
在twig文件中,我按如下方式渲染字段标签:
{{ form_label(form.zipcode) }}
我尝试了raw,escape,e过滤器,但是我的html页面中提供的结果总是字符串
<abbr title="Zone Improvement Plan">CAP</abbr> code
而不是相应的HTML代码!
有什么建议吗? 提前谢谢!
后来我找到了解决方案。 解决方案是在路径中禁用Symfony提供的标签块中的autoescape: symfony / src / Symfony / Bridge / Twig / Resources / views / Form / form_div_layout.html.twig
因此,在您的twig文件中,您必须将以下行放在表单之外: {%form_theme表单_self%}
{% block generic_label %}
{% spaceless %}
{% if required %}
{% set attr = attr|merge({'class': attr.class|default('') ~ ' required'}) %}
{% endif %}
<label{% for attrname,attrvalue in attr %} {{attrname}}="{{attrvalue}}"{% endfor %}>{% autoescape false %}{{ label|trans }}{% endautoescape %}</label>
{% endspaceless %}
{% endblock %}
答案 0 :(得分:8)
来自JeanValjean他自己:
{% autoescape false %}{{ form.zipcode.vars.label | trans }}{% endautoescape %}
要将此行为概括为整个应用,您可以覆盖标签的表单块:
{% block generic_label %}
{% spaceless %}
{% if required %}
{% set attr = attr|merge({'class': attr.class|default('') ~ ' required'}) %}
{% endif %}
<label{% for attrname,attrvalue in attr %} {{attrname}}="{{attrvalue}}"{% endfor %}>
{% autoescape false %}{{ label|trans }}{% endautoescape %}
</label>
{% endspaceless %}
{% endblock %}
答案 1 :(得分:7)
禁用自动空间过滤器只是为了渲染变量并不是最好的事情,因为当你阅读代码时,它并不是很清楚。
所以,而不是:
{% autoescape false %}{{ label|trans }}{% endautoescape %}
您可以使用:
{{ label|trans|raw }}