如何限制用户在Django中选择年份范围内的日期?
models.py
class Completion(models.Model):
start_date = models.DateField()
end_date = models.DateField()
batch = models.ForeignKey(Batch)
topic = models.ForeignKey(Topic)
在上面的代码中,DateField()
会在管理后台生成一个日期选择工具,用户可以在这里选择合适的日期,或者手动在文本框中输入日期。不过,这里有几个问题:
我想限制用户只能选择2000年到2100年之间的日期。
当用户在文本框中手动输入日期时,系统会接受任何符合yy-mm-dd格式的日期。我需要一些验证,确保用户不能输入不存在的日期。
1 个回答
11
看看这个验证器吧!
首先,你需要定义一个验证器:
from django.core.exceptions import ValidationError
def validate_current_century(value):
if value < 2000 or value > 2100:
raise ValidationError(u'%s is not a valid year!' % value)
现在你可以在你的模型字段中使用它:
class Completion(models.Model):
start_date = models.DateField(validators=[validate_current_century])
end_date = models.DateField(validators=[validate_current_century])
也可以在表单字段中使用:
from django import forms
class MyForm(forms.Form):
current_century_field = forms.DateField(validators=[validate_current_century])
更多详细信息可以在上面链接的文档中找到。