我的问题很简单,但我真的不知道该怎么做才能解决它。
这里的情况:
在 symfony2 (2.3.*) 中,我创建了一个表单(DocumentType.php + twig 渲染模板)。包括一个文件表格。有一些经典字段(文本、选项)加上一个文件输入。这个文件输入非常特别,我正在使用一个小技巧来自定义元素的渲染属性。
这里是EntityType类:
class DocumentType extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add(
'documentName',
'text',
array(
'label' => 'Nom du document'
)
)
->add(
'documentVersionCustom',
'text',
array(
'required' => false,
'label' => 'Version personnalisée'
)
)
->add(
'documentStatus',
'choice',
array(
'choices' => Document::getStatusChoices(),
'attr' => array(
'class' => 'select2',
),
'label' => 'Etat'
)
)
->add(
'file',
'file',
array(
'mapped' => false,
'attr' => array(
'class' => 'hidden'
),
'label' => 'Fichier',
'required' => true
)
);
}
public function setDefaultOptions(OptionsResolverInterface $resolver)
{
[...]
}
public function getName()
{
[...]
}
}
这里是Twig 模板(部分):
<div class="row">
{{ form_errors(form) }}
<legend class="span12">Informations du fichier</legend>
{{ form_label(form.documentName,'Nom du fichier',{'label_attr':{'class':'span4' }}) }}
{{ form_errors(form.documentName) }}
{{ form_widget(form.documentName,{'attr':{'class':'span8' }}) }}
{{ form_label(form.documentVersionCustom,'Version personnalisée',{'label_attr':{'class':'span4' }}) }}
{{ form_errors(form.documentVersionCustom) }}
{{ form_widget(form.documentVersionCustom,{'attr':{'class':'span8' }}) }}
{{ form_label(form.documentStatus,'État',{'label_attr':{'class':'span4' }}) }}
{{ form_errors(form.documentStatus) }}
<div class="row">
{{ form_widget(form.documentStatus,{'attr':{'class':'span8 select2' }}) }}
</div>
<div class="row">
{#{{ form_label(form.file,'Fichier',{'label_attr':{'class':'span4' }}) }}#}
{{ form_errors(form.file) }}
{{ form_widget(form.file,{'attr': {'style': 'display:none;' },'id' : 'browseFile' }) }}
<label for="browseFile" class="span4">Fichier</label>
<div class="row">
<div class="input-append span8">
<input type="text" name="subfile" id="subfile" onclick="$('#browseFile').click();">
<a class="btn btn-success" onclick="$('#browseFile').click();">Parcourir</a>
</div>
</div>
</div>
<div class="row">
</div>
{#<div class="row">#}
<input id="fileFormSubmitButton" type="submit" value="Ajouter" class="btn btn-primary span3"/>
<span class="span6"> </span>
<input id="fileFormCancelButton" type="button" value="Annuler" class="btn span3"/>
{#</div>#}
</div>
我对这个文件输入的小技巧是隐藏标准输入,并使用 javascript 将事件(单击、焦点)从样式元素重定向到隐藏元素(#subfile => form_widget(form.file))。
一切正常,但唯一的问题是文件输入。提交表单时,正确显示所需标准输入的验证消息,但对于此文件输入(这也是必需的),消息显示在浏览器的左下角(查看 « symfony 弹出工具提示 » 是让浏览器(在我的例子中是 firefox)不处于全屏模式。
我的问题:有没有办法在 symfony FormType 或其他任何地方指定“附加”错误消息到特定组件?
谢谢