当我试图通过继承 ErrorList 并覆盖其as_ul
方法来适应 Bootstrap 错误 html 类时,我遇到了奇怪的问题。
这是没有覆盖的形式:http://192.241.167.204/normal/
这是带有覆盖的表单:http://192.241.167.204/override/
请不要介意中文文本。
两种表单都将始终验证为错误输入,我没有弄乱的表单将显示正确的警告消息:
但我改变的形式并不那么幸运:
这是我在 bitbucket 中的 mercurial 中的完整来源。
因为这是我在 forms.py 中所做的:
@python_2_unicode_compatible
class BootstrapErrorList(ErrorList):
def as_ul(self):
if not self: return ''
return format_html('<ul class="errorlist alert alert-error">{0}</ul>',
format_html_join('', '<li>{0}</li>',
((force_text(e),) for e in self)
)
)
def __str__(self):
return self.as_ul()
class BootstrapForm(forms.Form):
def __init__(self, *args, **kwargs):
new_kwargs = {'error_class': BootstrapErrorList}
new_kwargs.update(kwargs)
super(BootstrapForm, self).__init__(*args, **new_kwargs)
为了比较,我用普通表单制作了一个表单类,从我的自定义表单类中制作了一个
class FormWithoutOverride(forms.Form):
iamalwayswrong = forms.CharField(max_length=200)
def clean(self):
cleaned_data = super(FormWithoutOverride, self).clean()
raise forms.ValidationError(u'錯')
return cleaned_data
class FormWithOverride(BootstrapForm):
iamalwayswrong = forms.CharField(max_length=200)
def clean(self):
cleaned_data = super(FormWithOverride, self).clean()
raise forms.ValidationError(u'錯')
return cleaned_data
观点相当简单:
# -*- coding: UTF-8 -*-
# Create your views here.
from django.shortcuts import render
from test_app.forms import *
def without_override(request):
if request.method == 'GET':
form = FormWithoutOverride()
if request.method == 'POST':
form = FormWithoutOverride(request.POST)
if form.is_valid(): # will never be valid
pass
return render(request, 'normal_form.html', {'form': form})
def with_override(request):
if request.method == 'GET':
form = FormWithOverride()
if request.method == 'POST':
form = FormWithOverride(request.POST)
if form.is_valid(): # will never be valid
pass
return render(request, 'override_form.html', {'form': form})
模板实现很简单(form.as_p),所以我这里就跳过了
这个问题在我的开发平台(Windows 7 Pro 64bit)上不存在,但在我的部署平台(Ubuntu 12.04 LTS 64bit,桌面和服务器都有这个)出现。我不确定如果我改用其他 linux 平台或 Mac 会发生什么。
这个问题不管我放在Apache2 + mod_wsgi还是manage.py runserver,gunicorn也没有。所有人都有相同的问题,所以它可能不是特定于部署的问题。
我完全不知道我做错了什么?任何线索将不胜感激。