我写了一个自定义小部件
class AutoCompleteWidget(widgets.TextInput):
"""
widget to show an autocomplete box which returns a list on nodes available to be tagged
"""
def render(self, name, value, attrs=None):
final_attrs = self.build_attrs(attrs, name=name)
if not self.attrs.has_key('id'):
final_attrs['id'] = 'id_%s' % name
if not value: value = '[]'
jquery = u"""
<script type="text/javascript">
$("#%s").tokenInput('%s', {
hintText: "Enter the word",
noResultsText: "No results",
prePopulate: %s,
searchingText: "Searching..."
});
$("body").focus();
</script>
""" % (final_attrs['id'], reverse('ajax_autocomplete'), value)
output = super(AutoTagWidget, self).render(name, "", attrs)
return output + mark_safe(jquery)
class MyForm(forms.Form):
AutoComplete = forms.CharField(widget=AutoCompleteWidget)
这个小部件使用一个jquery 函数,它根据数据库中的条目自动完成一个单词。您可以通过将 prePopulate 设置为表单中的 json 字符串来预设其初始值
['name': 'some name', 'id': 'some id']
我通过将表单字段的初始值设置为此 json 字符串来做到这一点
jquery_string = ['name': 'some name', 'id': 'some id']
form = MyForm(initial={'AutoComplete':jquery_string})
提交表单时,AutoComplete 的值以逗号分隔列表的形式返回,例如 12、45、43、66,如果我想要的话。
但是,如果表单中有错误,例如未输入必填字段,则自动完成字段的值现在是 12、45、43、66,而不是它需要的 json 字符串。
解决此问题的最佳方法是什么。我正在考虑覆盖表单类中的 clean 方法,但我不确定如何找出是否有任何其他元素返回了错误。例如
if forms.errors
form.cleaned_date['autocomplete'] = json string
return form.cleaned_data
谢谢