无法在Django中显示页面内容
有一个应用叫做 posts。
这里有一个模型:
class Post(models.Model):
text = models.TextField()
pub_date = models.DateTimeField("date published", auto_now_add=True)
author = models.ForeignKey(User, on_delete=models.CASCADE, related_name="posts")
group = models.ForeignKey(Group, on_delete=models.SET_NULL, related_name="posts", blank=True, null=True)
def __str__(self):
# выводим текст поста
return self.text
这里有一些网址设置:
path('posts/<str:username>/<int:post_id>/', views.post_view, name='post'),
这里有一些视图:
@login_required
def post_edit(request, username, post_id):
post = get_object_or_404(Post, pk=post_id, author__username=username)
print(post.text)
if request.user != post.author:
return redirect('post', username=username, post_id=post_id)
form = PostForm(request.POST or None, instance=post)
if form.is_valid():
form.save()
return redirect('post', username=username, post_id=post_id)
return render(request, 'post_new.html', {'form': form, 'post': post})
在视图中检查时,一切显示得都很正常:比如打印出 post.text 的内容。
但是,在 HTML 页面上却什么都不显示?
这里有一个 HTML 代码:
<main role="main" class="container">
<div class="row">
<div class="col-md-12">
<div class="card mb-3 mt-1 shadow-sm">
<div class="card-body">
<p class="card-text">
<a href="{% url 'profile' user.username %}">
<strong class="d-block text-gray-dark">@{{ post.author.username }}</strong>
</a>
{{ post.text }}
</p>
<div class="d-flex justify-content-between align-items-center">
<div class="btn-group">
<p>Author: {{ post.author.get_full_name }}</p>
<p>ID: {{ post.author.username }}</p>
</div>
<small class="text-muted">{{ post.pub_date }}</small>
</div>
</div>
</div>
</div>
</div>
</main>
问题出在哪里呢?为什么像 post.pub_date、post.author.get_full_name 这些都不工作?
在这个上下文中,它是可以工作的:
{% for post in posts %}
....
{{post.text}}
...
通过 {{ posts.0.author.username }} 可以正常显示。但是 {{ post.author.username }} 却不行。
我到底哪里做错了?
1 个回答
0
如果你使用 Modelmame.Objects.filter
来生成 posts
这个变量,它会变成一个列表。所以你需要使用下面的语法。
{% for p in posts %}
{{p.text}}
{% endfor %}
如果你使用 Modelmame.Objects.get
来生成 posts
这个变量,它会变成一个单独的对象。所以你需要使用下面的语法。
{{posts.text}}