简体   繁体   English

Django上下文处理器以显示图像

[英]Django context processor to show images

How to can add caption to each image in my images_people list? 如何为我的images_people列表中的每个图像添加标题?

This context_processor can be improved in the level practices sense? 可以在级别实践意义上改进context_processor吗?

I want show random images in my webpage, then I made a context processor 我想在网页中显示随机图像,然后制作一个上下文处理器

Context: 内容:

(previously added in my context_processors settings ...): (以前在我的context_processors设置中添加了...):

# -*- coding: utf-8 -*-

from random import choice

images_people = ['https://s3-sa-east-1.amazonaws.com/ihost-project/assets/img/bolivia2.jpg','2',
          'https://s3-sa-east-1.amazonaws.com/ihost-project/assets/img/bolivia3.jpg',
          'https://s3-sa-east-1.amazonaws.com/ihost-project/assets/img/bolivia4.jpg',
          'https://s3-sa-east-1.amazonaws.com/ihost-project/assets/img/bolivia-children.jpg',
          'https://s3-sa-east-1.amazonaws.com/ihost-project/assets/img/ElZocalo.jpg',
          'https://s3-sa-east-1.amazonaws.com/ihost-project/assets/img/israel.jpg',
          ]

def images(request):
    return {'images': choice(images_people)}

In my template I am invoking this context_processor: 在我的模板中,我正在调用此context_processor:

<div class="portrait">
    <div class="img-cont" style="background: url('{{ images  }}') no-repeat center; background-size:cover;">
    </div>
         # Add caption to image
         <!-- <span></span> -->
</div>

You could change the list in your context processor to be a list of 2-tuples of (url, caption). 您可以将上下文处理器中的列表更改为2元组(网址,标题)的列表。

images_people = [
    ('https://s3-sa-east-1.amazonaws.com/ihost-project/assets/img/bolivia2.jpg', 'Caption 1'), 
    ('https://s3-sa-east-1.amazonaws.com/ihost-project/assets/img/bolivia3.jpg', 'Caption 2),
    ...
]

def images(request):
    # n.b changed from `images` to `image` since it's a single image
    return {'image': choice(images_people)}

Then in your template, {{ images.0 }} will be the URL, and {{ images.1 }} will be the caption. 然后在您的模板中, {{ images.0 }}将成为URL, {{ images.1 }}将成为标题。

If you don't like accessing the tuple by index, you could look at NamedTuple or create a class. 如果您不喜欢按索引访问元组,则可以查看NamedTuple或创建一个类。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM