>当前的问题是我的表单向登录用户显示所有创建的投资组合。表单应仅显示登录用户创建的投资组合。
像这样:
associated_portfolios manytomany field = ...objects.filter(user=user_id)
我不确定这是否应该在 forms.py 或 views.py 中实现,如果是,如何实现。我一直在浏览 django 文档并找到"formfield_for_manytomany",但不确定这是否仅适用于管理员。
Models.py
class Portfolio(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE)
name = models.CharField(max_length=20)
description = models.CharField(max_length=250, blank=True, null=True)
class Post(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE)
title = models.CharField(max_length=50)
body = RichTextUploadingField(blank=True, null=True)
associated_portfolios = models.ManyToManyField(Portfolio, blank=True)
created_on = models.DateField(auto_now_add=True, editable=False)
Views.py
class PostCreate(CreateView):
model = Post
form_class = PostCreateForm
def formfield_for_manytomany(self, db_field, request, **kwargs):
self.fields['associated_portfolios'] = Portfolio.objects.filter(user=self.request.user)
return super().formfield_for_manytomany(db_field, request, using=self.using, **kwargs)
forms.py
class PortfolioCreateForm(ModelForm):
class Meta:
model = Portfolio
fields = ['user', 'name', 'description']
class PostCreateForm(ModelForm):
class Meta:
model = Post
fields = ['user', 'title', 'body', 'category', 'associated_portfolios']
由于您使用的是ModelForm
,因此associated_protfolios
字段将是 [docs]ModelMultipleChoiceField
。此字段具有queryset
属性 [docs]。我们要修改该属性。
Django的CreateView
有一个方法get_form
,在这种情况下会抓住你的PostCreateForm
。这是过滤字段查询集的好地方,因为我们可以访问用户:
class PostCreate(CreateView):
model = Post
form_class = PostCreateForm
def get_form(self, *args, **kwargs):
form = super().get_form(*args, **kwargs) # Get the form as usual
user = self.request.user
form.fileds['associated_portfolios'].queryset = Portfolio.objects.filter(user=user)
return form
你试过这个吗
self.fields['associated_portfolios'] = Post.objects.filter(associated_portfolios__portfolio__user=request.user)
或
user_posts = Post.objects.filter(user=request.user)
self.fields['associated_portfolios'] = user_posts.associated_portfolios.all()
在此处阅读有关 M2M 关系查询的更多信息,因为我认为您的问题可能出在它身上。
另外,我不确定您的实际数据是否正确,并且它给出了正确的结果,因为针对当前用户过滤Portfolio
模型以获取其对象看起来适合我,但无论如何再次仔细检查所有内容。
最后,将related_name
添加到您的模型字段中,以便您可以轻松地将其用于反向关系,而不是使用 Django 的默认命名,它会更清晰并提供更好的理解。