шаблон django - отображение изображений в таблице - PullRequest
0 голосов
/ 01 апреля 2012

Я не могу получить изображения (или ссылки на изображения) для отображения в шаблоне.Все остальное работает над шаблоном, кроме изображения "render_thumbnail", которое определяется в пользовательском методе модели.Что я делаю неправильно?-t между прочим, render_thumbnail работает с другим шаблоном, когда я работаю только с таблицей Images и отображаю с помощью - images.render_thumbnail.Спасибо.

Models.py

class Listings(models.Model):
    createdate = models.DateTimeField(auto_now_add=True)
    expirydate = models.DateTimeField(null=True, blank=True)
    price = models.IntegerField(null=True, blank=True)
    broker_y_n = models.CharField(max_length=1, blank=True, choices=broker, default='n')
    listing_type = models.ForeignKey(ListingType)
    listing_status = models.ForeignKey(ListingStatus, default=3)
    customer = models.ForeignKey(Customer)

class Image(models.Model):
    title = models.CharField(max_length=60, blank=True, null=True)
    image = models.ImageField(upload_to="images/", blank=True, null=True)
    thumbnail = models.ImageField(upload_to="images/", blank=True, null=True)
    thumbnail2 = models.ImageField(upload_to="images/", blank=True, null=True)
    #tags = models.ManyToManyField(Tag, blank=True)
    #albums = models.ManyToManyField(Album, blank=True)
    created = models.DateTimeField(auto_now_add=True)
    #rating = models.IntegerField(default=50)
    width = models.IntegerField(blank=True, null=True)
    height = models.IntegerField(blank=True, null=True)
    listings = models.ForeignKey(Listings)
    def save(self, *args, **kwargs):
        # Save image dimensions
        super(Image, self).save(*args, **kwargs)
        im = PImage.open(pjoin(MEDIA_ROOT, self.image.name))
        self.width, self.height = im.size
        # large thumbnail
        fn, ext = os.path.splitext(self.image.name)
        im.thumbnail((256,256), PImage.ANTIALIAS)
        thumb_fn = fn + "-thumb2" + ext
        tf2 = NamedTemporaryFile()
        im.save(tf2.name, "JPEG")
        self.thumbnail2.save(thumb_fn, File(open(tf2.name)), save=False)
        tf2.close()
        # small thumbnail
        im.thumbnail((60,60), PImage.ANTIALIAS)
        thumb_fn = fn + "-thumb" + ext
        tf = NamedTemporaryFile()
        im.save(tf.name, "JPEG")
        self.thumbnail.save(thumb_fn, File(open(tf.name)), save=False)
        tf.close()
        super(Image, self).save(*args, **kwargs)
    def size(self):
        # Image size #
        return "%s x %s" % (self.width, self.height)
    def render_thumbnail(self):
        return mark_safe("""<a href = "/media/%s"><img border="0" alt=""     src="/media/%s" /></a>""" % ((self.image.name, self.thumbnail.name)))
    #render_thumbnail.allow_tags = True
    def render_thumbnail2(self):
        return mark_safe("""<a href = "/media/%s"><img border="0" alt="" src="/media/%s" /></a>""" % ((self.image.name, self.thumbnail2.name)))
    #render_thumbnail.allow_tags = True
    def __unicode__(self):
    return self.image.name

View.py

def details_customer(request, user_id):
    customer = get_object_or_404(Customer, user=user_id)
    cusnum=customer.id
    image = Image.objects.all()    
    listings = Listings.objects.filter(customer=cusnum).values(
        'id',
        'price',
        'listing_type__desc',
        'listing_status',
        'listing_status__desc',
        'canoekayak__builder',
        'image__title',
        'image__thumbnail',
        'image__render_thumbnail',        
        )
    context = Context({
        'title': 'Details',
        'customer': customer,
        'image' : image,        
        'listings' : listings,
        })
    return render_to_response('bsmain/details.html', context)

Шаблон таблицы

<TABLE id="some_id">    
<TBODY>
    {% load humanize %}
    {% for row in listings %}
    <tr>
        <td>{{ row.id }}</td>
        <td align="right">{{row.price|intcomma}}</td>
        <td>{{ row.listing_type__desc}}</td>
        <td>{{ row.listing_status}}</td>
        <td>{{ row.listing_status__desc}}</td>
        <td>{{ row.canoekayak__builder}}</td>
        <td>{{ row.image__title}}</td>
        <td>{{ row.image__thumbnail}}</td
        <td>{{ row.image__render_thumbnail}}</td            
    </tr>
    {% endfor %}
</TBODY>

1 Ответ

2 голосов
/ 03 апреля 2012

Если вы хотите сделать ваш код проще, я бы рекомендовал использовать приложение django-tables2 .Этот подход может решить все ваши проблемы с генерацией таблиц.

Как видно из документации:

django-tables2 упрощает задачу преобразования наборов данных в HTML-таблицы.Имеет встроенную поддержку разбиения на страницы и сортировки.Он делает для таблиц HTML то же, что django.forms делает для форм HTML.например,

Его функции включают в себя:

  • Источником данных может быть любая итерация, но включена специальная поддержка наборов запросов Django.
  • Встроенный пользовательский интерфейс не используетна JavaScript.
  • Поддержка автоматического создания таблиц на основе модели Django.
  • Поддержка пользовательских функций столбцов с помощью подклассов.
  • Разбиение на страницы.
  • Таблица на основе столбцовsorting.
  • Тег шаблона для включения тривиального рендеринга в HTML.
  • Общий миксин представления для использования в Django 1.3.

Создать таблицу так же просто, как:

import django_tables2 as tables

class SimpleTable(tables.Table):
    class Meta:
        model = Simple 

Это будет использоваться в представлении:

def simple_list(request):
    queryset = Simple.objects.all()
    table = SimpleTable(queryset)
    return render_to_response("simple_list.html", {"table": table},
                              context_instance=RequestContext(request))

И, наконец, в шаблоне:

{% load django_tables2 %} 
{% render_table table %}

В этом примере показан один из самых простых случаев:но django-tables2 может сделать намного больше!Ознакомьтесь с документацией для получения более подробной информации.

Также можно использовать словарь вместо набора запросов.

Для отображения изображений в ячейках таблицы вы можете использовать пользовательскиестолбец таблицы HtmlColumn

from django.utils.safestring import mark_safe
import django_tables2 as tables

from pytils.numeral import get_plural
class HtmlColumn(tables.Column):
    def render(self, value):
        return mark_safe(value)

или создайте новый ImageColumn таким же образом и передайте только атрибут src вместо целого тега img .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...