[英]Django CreateView ModelForm dropdown field queryset filter
這是我第一次真正使用Django(1.6)並且我無法解決這個問題:
我正在嘗試限制CreateView的下拉列表,以僅顯示項目模型中具有活動狀態(2)的項目:
class ProjectStatus(models.Model):
name = models.CharField(max_length=8)
class Project(models.Model):
name = models.CharField(max_length=30)
status = models.ForeignKey(ProjectStatus)
class WorkLog(models.Model):
project = models.ForeignKey(Project)
author = models.ForeignKey(User)
log_date = models.DateField( default=datetime.date.today)
accomplishments = models.TextField()
我的forms.py:
class WorklogCreateForm(ModelForm):
class Meta:
model = WorkLog
fields = [ 'project', 'log_date', 'accomplishments' ]
def __init__(self, *args, **kwargs):
super(WorklogCreateForm, self).__init__(self, *args, **kwargs)
self.fields['project'].queryset = Project.objects.filter(Project.status == 2)
和來自views.py的我的CreateView:
class WorklogCreate(CreateView):
form_class = WorklogCreateForm
success_url = reverse_lazy('dashboard')
但我得到錯誤:
TypeError at /log/add/
'bool' object has no attribute '__getitem__'
如果我將我的過濾器更改為(Project.status.id == 2)
我會得到:
AttributeError at /log/add/
'ReverseSingleRelatedObjectDescriptor' object has no attribute 'id'
我覺得我很接近,但顯然並不完全掌握。 有任何想法嗎? 謝謝。
嘗試像這樣過濾。
self.fields['project'].queryset = Project.objects.filter(status_id=2)
你很接近,但由於某些原因混合了看起來像SQLAlchemy的語法。
此外,通過任意分配的數字(PK)過濾您的查詢集的想法是荒謬的。
self.fields['project'].queryset = Project.objects.filter(status__name="foo")
如果只有你的狀態名稱被標記為unique=True
,那么會更有意義。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.