Python/Django - получает значение ManyToManyField в теге for
Я не могу получить значение, связанное с изображением, когда использую {% for %}
с классом ст. Я пытался с select_related, но я не знаю, как определить изображение, которое будет правильно отображаться в src=""
атрибут моего <img />
тег
Есть ли чистый способ сделать так, как я хочу?
models.py
class Image(models.Model):
gallery = models.ManyToManyField(Gallery)
name = models.CharField(max_length=100)
image = models.ImageField(upload_to='static/images/gallery')
def __str__(self):
return self.name
class Article(models.Model):
section = models.ForeignKey(Menu)
title = models.CharField(max_length=100)
text = models.TextField()
type = models.ForeignKey(Type)
image = models.ManyToManyField(Image)
def __str__(self):
return self.title
views.py
def index(request):
slider = Article.objects.all()
images = Image.objects.all()
return render(request, 'cms/index.html', locals())
шаблон
{% for i in slider %}
<li>
<img src="{{i.image}}" alt="{{i.title}}"/>
<h2>{{i.title}}</h2>
<p>{{i.text}}, {{i.image_url}}</p>
</li>
{% endfor %}
2 ответа
Решение
Вы должны использовать 2 forloop для отображения изображений во многих таблицах.
{% for i in slider %}
<li>
{% for im in i.image.all %}
<img src="{{im.image.url}}" alt="{{im.name}}"/>
{% endfor %}
<h2>{{i.title}}</h2>
<p>{{i.text}}, {{i.image_url}}</p>
</li>
{% endfor %}
Article.image
является полем ManyToMany. Какое изображение вы хотите отобразить? Первый?
<img src="{{i.image.all.0.image.url}}" alt="{{i.title}}"/>
Все?
{% for im in i.image.all %}
<img src="{{im.image.url}}" alt="{{im.name}}"/>
{% endfor %}