Django - 显示ImageField

时间:2013-07-24 23:03:38

标签: python django imagefield

我刚开始使用django而且我没有找到很多关于如何显示imageField的信息,所以我做了这个:

models.py

class Car(models.Model):
    name = models.CharField(max_length=255)
    price = models.DecimalField(max_digits=5, decimal_places=2)
    photo = models.ImageField(upload_to='site_media')

views.py

def image(request):
    carx = Car()
    variables = RequestContext(request,{
        'carx':carx
    })
    return render_to_response('image.html',variables)

image.html

{% extends "base.html" %}
{% block content %}
   <img src=carx />
{% endblock %}

我已经保存了一个图像,因为终端,我知道在那里,如果在image.html中执行此操作:

{% block content %}
    {{ carx }}
{% endblock %}

输出是:汽车对象

谁能告诉我我的错误在哪里?

非常感谢。

3 个答案:

答案 0 :(得分:33)

ImageField包含url属性,您可以在模板中使用该属性来呈现正确的HTML。

{% block content %}
    <img src="{{ carx.photo.url }}">
{% endblock %}

答案 1 :(得分:2)

您还可以使用Settings.py中的静态网址。在应用程序的静态目录中创建一个目录,例如&#34;上传&#34;,同样在models.py中的模型中更改此内容。

使用以下代码:

<img src="{% static carx.photo.url %}" />

答案 2 :(得分:-1)

感谢所有人,我以这种方式修复它。

views.py

def image(request):
carx = Car.objects.all()
for mycar in carx:
    MyCar = mycar.photo.url
variables = RequestContext(request,{
    'carx':MyCar
})
return render_to_response('image.html',variables)

image.html

{% extends "base.html" %}

{% block content %}
     <img src="{{ MEDIA_URL }}{{ carx }}"/>
{% endblock %}

settings.py

 MEDIA_URL = '/Users/gcarranza/PycharmProjects/django_bookmarks/'
 STATIC_URL = '/Users/gcarranza/PycharmProjects/django_bookmarks/site_media/'
 STATICFILES_DIRS = (
 '/Users/gcarranza/PycharmProjects/django_bookmarks/site_media',)

现在我知道carx.photo.url检索文件的绝对路径,并且唯一要加载为静态文件。