Django 表单:仅显示来自登录用户的多对多对象



>当前的问题是我的表单向登录用户显示所有创建的投资组合。表单应仅显示登录用户创建的投资组合。

像这样:

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 的默认命名,它会更清晰并提供更好的理解。

相关内容

  • 没有找到相关文章

最新更新