我无法在 ModelForm 中创建 ModelChoiceField 查询集。相关的 model.objects 管理器已被覆盖以过滤结果,以便仅获取实际用户创建的实例。这是我的模型:
class Bloc(ModelPrive):
TYPE_BLOC = (
('pleinchamps', 'plein champs'),
('tunnel', 'tunnel'),
('pepiniere', 'pépinière'),
('autre', 'autre'),
)
nb_planche = models.IntegerField(null=True)
caracteristique = models.CharField(max_length=200, null= True, blank=True)
geom = models.PolygonField(srid=4326)
type_bloc = models.CharField(max_length=200, blank=True, choices=TYPE_BLOC)
nom = models.CharField(max_length=200, null=True, unique= True)
class ModelPrive(models.Model):
created_by = models.ForeignKey(User, blank=True, null=True, on_delete=models.SET_NULL, editable=False)
class Meta:
abstract = True
objects = ModelPriveManager()
class ModelPriveManager(models.Manager):
def get_queryset(self):
user = get_current_user()
return super().get_queryset().filter(created_by=user)
在我的经理中, get_current_user() 返回已被自定义中间件拦截的实际用户。
这是我的表格:
class BlocFormList(ModelForm):
choix_bloc = forms.ModelChoiceField(queryset = Bloc.objects.all().order_by('nom'), required=True)
class Meta:
model = Bloc
fields = ['choix_bloc']
这是我的观点:
def planification(request):
form_bloc = BlocFormList()
if request.method == 'POST':
# some other code
return render(request, 'planification.html', locals())
问题是,当我在视图中执行 Bloc.objects.all() 时,我得到了预期的答案 (Bloc.objects.filter(created_by=user)) 但是当它在模型表单的查询集中完成时,它什么也不返回(好像没有活动用户)。
经过一番检查,我发现模型表单查询集甚至没有进入管理器。
如果有人知道如何纠正这个问题,我没有更多的想法。