视图中的 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 %}
我想在他们的个人资料页面中显示特定用户的所有 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 %}