我正在尝试使用此jQuery 插件提交多项选择字段以呈现多项选择。
我的表格如下:
class BackupForm(forms.Form):
def __init__(self, *args, **kwargs):
self.user = kwargs.pop('user', None)
super(BackupForm, self).__init__(*args, **kwargs)
self.fields['contas_choice'] = forms.MultipleChoiceField(
choices=get_backup_choices(self.user)
)
for field in self.fields:
self.fields[field].widget.attrs.update({'class': 'form-control', })
self.fields['contas_choice'].widget.attrs.update(
{
'name': 'from[]',
'id': 'search',
'class': 'form-control',
'size': '8',
'multiple': 'multiple',
}
)
contas_choice = forms.MultipleChoiceField(required=False)
# other fields
在我的模板上:
<form action="" class="form-horizontal" method="post">{% csrf_token %}
<div class="row">
<div class="col-xs-5">
{% for choice in form.contas_choice %}
{{ choice }}
{% endfor %}
</div>
<div class="col-xs-2">
<button type="button" id="search_rightAll" class="btn btn-block"><i
class="glyphicon glyphicon-forward"></i></button>
<button type="button" id="search_rightSelected" class="btn btn-block"><i
class="glyphicon glyphicon-chevron-right"></i></button>
<button type="button" id="search_leftSelected" class="btn btn-block"><i
class="glyphicon glyphicon-chevron-left"></i></button>
<button type="button" id="search_leftAll" class="btn btn-block"><i
class="glyphicon glyphicon-backward"></i></button>
</div>
<div class="col-xs-5">
<select name="to[]" id="search_to" class="form-control" size="8" multiple="multiple"></select>
</div>
</div>
<div id="actions" class="row">
<div class="col-md-12">
<button type="submit" class="btn btn-primary">Baixar</button>
<a href="/listar-contas/" class="btn btn-default">Cancelar</a>
</div>
</div>
</form>
这就像我想要的那样呈现选择字段,就像在插件参考的示例中一样。
但是当我尝试提交表单时,我收到一条 HTML 消息说“请在列表中选择一个项目”,即使我已将所有项目移动到右侧框。因此,我无法提交表单,我什至没有收到任何 Django 错误,因为它立即未能通过 HTML 验证。
我应该怎么做才能使右侧框中的所有项目都提交?
谢谢!