質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Q&A

解決済

1回答

207閲覧

Django:1ページに複数のモデルを表示したい

kero16

総合スコア9

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

0グッド

0クリップ

投稿2020/07/08 00:44

前提・実現したいこと

1ページ内に3つのモデルを表示したいと思っています。

下記のようなviews.pyのコードで
2つまでは表示できる様になったのですが、
3つ目を表示するための方法がわかりません。

解決方法をご教示いただけましたら幸いです。
よろしくお願いいたします。

該当のソースコード

Python

1######### views.py ######### 2 3from django.shortcuts import render 4from .models import CardModel, MessageModel, imageModel 5from django.views.generic import ListView 6 7# Create your views here. 8class CardList(ListView): 9 templage_name = 'list.html' 10 model = CardModel 11 12 def get_context_data(self, **kwargs): 13 context = super().get_context_data(**kwargs) 14 context['message'] = MessageModel.objects.get() 15 return context 16

Python

1######### models.py ######### 2 3from django.db import models 4 5# (1)複数の写真とテキスト -> 表示OK 6class CardModel(models.Model): 7 text = models.TextField(blank=True) 8 images = models.ImageField(upload_to='', blank=True, null=True) 9 10 def __str__(self): 11 return self.text 12 13 14# (2)メッセージ -> 表示OK 15class MessageModel(models.Model): 16 message = models.TextField(blank=True) 17 18 def __str__(self): 19 return self.message 20 21 22# (3)メイン写真 -> 表示できない 23class imageModel(models.Model): 24 main_image = models.ImageField(upload_to='', blank=True, null=True) 25 26 def __str__(self): 27 return self.message

Python

1######### list.html ######### 2 3{% extends 'base.html' %} 4 5 6{% block content %} 7 8<!--メイン写真表示--> 9<img class="circle" src="{{ main_image }}"> 10 11 12<!--メッセージ表示 OK--> 13<P>{{ message | linebreaks }}</P> 14 15 16 17<!--複数の写真表示 OK--> 18{% for object in object_list %} 19  <div class="col thumbs"> 20    <a href="{{ object.images.url }}" rel="lightbox" title="{{ object.text }}"> 21    <img src="{{ object.images.url }}"></a> 22  </div> 23{% endfor %} 24 25 26{% endblock content %} 27 28

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

下記などのようにすればImageModelモデルインスタンスを表示できると思います。

python

1class CardList(ListView): 2 # snip 3 def get_context_data(self, **kwargs): 4 context = super().get_context_data(**kwargs) 5 # snip 6 context['image_model'] = ImageModel.objects.all().first() 7 return context

html

1<!-- list.html --> 2<img src="{{ image_model.main_image.url }}" />

投稿2020/07/08 03:16

hasami

総合スコア1277

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kero16

2020/07/08 03:49

無事表示できました! 検索してもなかなか解決方法を見つけられず諦めかけていたので嬉しいです。 本当にありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問