我有两个模型Project
和Group
。我的小组属于一个特定的项目。我的组有字段 project =foreignKey(Project)
和 parent =foreignKey('self')
。
我可以使用 limit_choices_to
来确保外键 parent
中的选项仅包含同一项目内的组吗?
我正在考虑类似的事情
def limit_choices_to(self):
return {'project': self.project}
最佳答案
这在模型级别是不可能做到的,但您可以在表单的构造函数中更改此字段的查询集。
class GroupForm(forms.ModelForm):
def __init__(self, *args, **kwargs):
super(GroupForm, self).__init__(*args, **kwargs)
if self.instance.project:
self.fields['parent'].queryset = Group.objects.filter(
project=self.instance.project)
更新:要在管理员中执行此操作,您必须设置 form
ModelAdmin
的属性:
class GroupAdmin(admin.ModelAdmin):
form = GroupForm
关于django - 在 Django 中使用 limit_choices_to 中的字段值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28901089/