前提・実現したいこと
Djangoの勉強をしています。
一対多のリレーションから情報を取得し、テンプレートに表示したいと考えています。
アイテムに複数カテゴリが紐ついている場合、1アイテムにカテゴリが複数紐付く形で出力したいです。
1アイテムに1カテゴリを紐付けループさせることはできたのですが、1アイテムに紐付くカテゴリすべてを
出力させるための方法がわかりません。
・実現できた
アイテム1
カテゴリ1
アイテム1
カテゴリ2
…
・どう実現すればいいのかわからない
アイテム1
カテゴリ1 カテゴリ2 カテゴリ3
アイテム2
カテゴリ1 カテゴリ2
お忙しい中、お時間を割いていただき大変恐縮ですが、ご教授いただけますと幸いです。
該当のソースコード
python
1models.py 2 3class Item(models.Model): 4 item_id = models.CharField(primary_key=True, max_length=10) 5 title = models.CharField(max_length=250, blank=True, default=DEFALT_CHAR) 6 7class ItemCategory(models.Model): 8 item = models.ForeignKey(Item, on_delete=models.CASCADE) 9 category = models.CharField(max_length=150, blank=True, default=DEFALT_CHAR) 10 queryset = Item.objects.prefetch_related('itemcategory_set')
python
1views.py 2 3class ItemCategoryView(ListView): 4 model = Item 5 paginate_by = 50 6 template_name = 'blog/item_category.html'
html
1item_category.html 2 3{% for object in object_list %} 4 <li>{{ object.title }}</li> 5 <li>{{ object.category }}</li> 6{% endfor %}
バージョン
Python3.7
Django3.0
MySQL8.0
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。