1
大家好! 我只是開始Django編程的一種方式,所以有時真的會感到困惑。Django objects.all()不顯示任何內容
我試圖從數據庫中顯示我的所有對象,但是當打開頁面時,它只是空的。
有內容添加,我以前試過ListView和它爲我工作。但現在我需要像網格一樣拋棄物體,這是這種方法的一個問題。
對任何幫助將非常感謝!
models.py
from django.db import models
class Post(models.Model):
title = models.CharField(max_length=140)
body = models.TextField()
date = models.DateField()
image = models.ImageField(upload_to='bons_images/%Y/%m/%d')
def __str__(self):
return self.title
views.py
from django.shortcuts import render, render_to_response
from django.template import RequestContext
from django.views import generic
from blog.models import Post
def image(request):
post = Post()
variables = RequestContext(request, {
'post': post
})
return render_to_response('blog/post.html', variables)
# class IndexView(generic.ListView):
# template_name = 'blog/blog.html'
# context_object_name = 'all_posts'
#
# def get_queryset(self):
# return Post.objects.all()
def index(request):
posts = Post.objects.all()
return render(request, 'blog/blog.html', {'posts': posts})
urls.py
from django.conf.urls import url, include
from django.views.generic import ListView, DetailView
from blog.models import Post
from blog import views
urlpatterns = [
url(r'^$', views.index, name='index'),
url(r'^(?P<pk>\d+)$', DetailView.as_view(model=Post, template_name='blog/post.html')),
]
blog.html
{% extends 'base.html' %}
{% block content %}
{% if all_posts %}
{% for post in all_posts %}
<div class="container-fluid">
<div class="row">
<div class="col-sm-3 col-lg-4">
<div class="thumbnail">
<a href="/blog/{{ post.id }}">
<h5>{{ post.date|date:'Y-m-d' }} {{ post.title }}</h5>
<img src="{{ post.image.url }}" style="width: 50%; height: 50%"/>
</a>
</div>
</div>
</div>
</div>
{% endfor %}
{% endif %}
{% endblock %}
順便說一下,它怎麼能夠顯示你的對象,如在網格中,沒有列出,使用引導或等。
謝謝!
ohhh ...那是一個來自ListView的變量,我很留神,謝謝你的朋友!有一個機會,你知道嗎,如何實現我的對象看起來像一個網格,而不是列表 – Michael
不知道你的網格是什麼意思,但你可以在你的HTML中使用表標記,如果這是你想要的。 –
我的意思是,我需要動態顯示一行中的幾個對象。目前,使用我的模板,他們將按照順序依次排列。 – Michael