视图中的 Django 查询集没有向 html 模板返回任何内容

Django queryset in view isn't returning anything to the html template

我想在他们的个人资料页面中显示特定用户的所有 post,但只显示他们的个人资料信息,而不是 post。

我的初始代码只是试图循环遍历模板中的 posts,如下所示:

      {% for post in user.posts.all %}
      {% endfor %}

但是没有用。所以我接下来尝试了这个。

views.py

     user = get_object_or_404(User, username=username)
     post = Post.objects.filter(created_by=user.id)

     context = {
          'user': user,
          'post': post
     }

     return render(request, 'users/profile.html', context)

profile.html

<div class="user-profile">
    <img class="rounded-circle account-img" src="{{ user.profile.image.url }}">
    {{ user.username }}
    {{ user.email }}
</div>

<div class="user-post-model">
{% for post in posts %}
   <img class="rounded-circle post-img" src="{{ post.created_by.profile.image.url }}">
   {{ post.title }}
   {{ post.content|safe }}
   {{post.tag}}
   {{ post.created_by }}
   {{ post.created_at|naturaltime}}
{% endfor %}
</div>

也没用

我还尝试使用 ListView 来 post post。它起作用了,但它没有显示特定用户的个人资料信息,而是显示了登录用户的个人资料信息,但显示了特定用户的 posts.

像这样:

def profile(request, username):
     user = get_object_or_404(User, username=username)

     context = {
          'user': user
     }

     return render(request, 'users/profile.html', context)

class UserPostListView(ListView):
     model = Post
     template_name = 'users/profile.html'
     context_object_name = 'posts'
     
     def get_queryset(self):
          user = get_object_or_404(User, username=self.kwargs.get('username'))
          return Post.objects.filter(created_by=user).order_by('-created_at')

这是post模型

class Post(models.Model):
     title =  models.CharField(max_length=255)
     content = RichTextField(blank=True, null=True, max_length=30000)
     created_at = models.DateTimeField(default=timezone.now)
     created_by = models.ForeignKey(User, on_delete=models.CASCADE)
     tag =  models.CharField(max_length=255, default='uncategorised')

     class Meta:
          ordering = ('-created_at',)

     def __str__(self):
          return self.title + ' | ' + str(self.created_by)

     def get_absolute_url(self):
          return reverse("post-detail", kwargs={"pk": self.pk})

怎么了?

要将相关的 Post 对象循环到 User,请使用 _set (Django Docs)。

所以在你的情况下 user.post_set:

{% for post in user.post_set.all %}
    {{ post.title }}
{% endfor %}