Python Django:在页面中列出每个类别的产品
我有几个类别,我想按以下格式列出每个类别的产品(类别是产品的FK): 第一类 一堆产品 类别N 一堆产品 我已经尝试了很多方法,但到目前为止,我只得到类别,而没有产品显示在我的HTML models.pyPython Django:在页面中列出每个类别的产品,python,django,django-models,django-templates,django-views,Python,Django,Django Models,Django Templates,Django Views,我有几个类别,我想按以下格式列出每个类别的产品(类别是产品的FK): 第一类 一堆产品 类别N 一堆产品 我已经尝试了很多方法,但到目前为止,我只得到类别,而没有产品显示在我的HTML models.py class Category(models.Model): title = models.CharField(max_length=225) slug = models.SlugField(unique=True, blank=True, null=True) de
class Category(models.Model):
title = models.CharField(max_length=225)
slug = models.SlugField(unique=True, blank=True, null=True)
def __str__(self):
return self.title
def get_absolute_url(self):
return reverse('category_detail', kwargs={'slug': self.slug})
@property
def get_products(self):
return Products.objects.filter(category=self.title)
class Products(models.Model):
title = models.CharField(max_length=225)
image = models.ImageField(upload_to=upload_image_path, null=True, blank=True)
blank=True, on_delete=models.CASCADE)
categories = models.ForeignKey(Category, related_name='Category', blank=True, on_delete=models.CASCADE) #this
gender = models.CharField(max_length=20, choices=GENDER_CHOICES, default="male")
objects = ProductManager()
def get_absolute_url(self):
return reverse('product_detail', args=(self.id,))
def __str__(self):
return self.title
views.py
def categories_m(request):
query_Set = models.Category.objects.all()
page = request.GET.get('page', 1)
paginator = Paginator(query_Set, 20)
try:
cat = paginator.page(page)
except PageNotAnInteger:
cat = paginator.page(1)
except EmptyPage:
cat = paginator.page(paginator.num_pages)
return render(request, 'products/categories.html', {'categories': cat})
html
{%extends'base.html%}
{%block content%}
{categories%%中的类别为%s}
{{category}}
{categories.get_products%}
{{product}}
{%endfor%}
{%endfor%}
{%endblock%}
在模板中应该是类别
,而不是类别
。并在您的模型中按类别标题筛选产品
@property
def get_products(self):
return Products.objects.filter(categories__title=self.title)
{%extends'base.html%}
{%block content%}
{categories%%中的类别为%s}
{{category}}
{category.get_products%中的产品的%
{{product}}
{%endfor%}
{%endfor%}
{%endblock%}
您可以从字段中删除相关的\u name
属性
class Products(models.Model):
categories = models.ForeignKey(Category, blank=True, on_delete=models.CASCADE)
然后在模板中可以使用category.products\u set.all
{% extends 'base.html' %}
{% block content %}
{% for category in categories %}
<h1>{{ category }}</h1>
{% for product in category.products_set.all %}
<p>{{ product }}</p>
{% endfor %}
{% endfor %}
{% endblock %}
{%extends'base.html%}
{%block content%}
{categories%%中的类别为%s}
{{category}}
{category.products_set.all%}中的产品为%
{{product}}
{%endfor%}
{%endfor%}
{%endblock%}
不,这不起作用。我以前试过这个。它抛出:无法将关键字“category”解析到字段中。选项包括:活动、类别、类别\u id、性别、id、图像、标题……@inconu在您的模型中删除@property
装饰器。是否尝试导入类别
并设置query\u Set=Category.objects.all()
?我不确定这是什么原因,只是说。让我们看看。他为什么需要删除相关的名称??他可以使用category.category.all
.Hm。。。就我而言,这可能是拙劣的措辞:我的意思是,定义相关的\u名称(或使用默认名称)在语义上更为正确,这样您就可以理解您得到的对象的类型。使用related\u name='Category'
有点混乱,因为它不返回Category
对象。哦,是的。你说得对<代码>相关\u名称
应该与产品
相关。
class Products(models.Model):
categories = models.ForeignKey(Category, blank=True, on_delete=models.CASCADE)
{% extends 'base.html' %}
{% block content %}
{% for category in categories %}
<h1>{{ category }}</h1>
{% for product in category.products_set.all %}
<p>{{ product }}</p>
{% endfor %}
{% endfor %}
{% endblock %}