0

我有两个模型

注意:我删除了一些代码以使问题变得简单

class Categories(models.Model):
    category_name           = models.CharField(max_length=100, null=True)

class Courses(models.Model):
    course_name             = models.CharField(max_length=200)
    category                = models.ForeignKey(Categories, on_delete = models.CASCADE,)

例如,如果我有 3 个类别(PHP、Python、Javascript),并且每个类别都有一个与之相关的课程,就像这样

PHP = php_course1, php_course2, php_course3

Python = python_course1, python_course2, python_course3

Javascript = javascript_course1, javascript_course2, javascript_course3

因此,当有人单击任何类别时,我想要什么,它会将他带到另一个页面,该页面仅包含与该类别相关的课程。

这就是我为实现这一目标所做的一切

视图.py

class CategoriesListView(ListView):
   model               = Categories
   template_name       = 'category_list.html'
   context_object_name = 'category_list'

class CategoriesDetailView(DetailView):
   model               = Categories
   template_name       = 'category_detail.html'
   context_object_name = 'category_detail'

第一个模板“category_list.html”

{% for category in category_list %}

  <a href="{% url 'category' category.slug %}" class="btn">{{ category.category_name }}</a>

{% endfor %}

第二个模板'category_detail.html'

{% for course in category_detail.courses_set.all  %}

  <h1> {{ course.course_name }} </h1>

{% ednfor %}

如果我单击“javascript 类别”,这将非常有效,例如它只会显示“javascript 课程”。

问题是我想过滤课程,但是因为我使用了像这样的相关对象,所以我在视图上没有上下文,所以我可以玩

所以要么我做的方式是错误的,这就是为什么它限制了我,还有另一种好方法我想让你告诉我,或者这是一个好方法,我可以做一些事情来过滤和玩“课程” ' 对象

我搜索并找到了这个,但这给了我所有“课程”,而不仅仅是与特定“类别”相关的课程

def get_context_data(self, **kwargs):
    context = super(CategoriesDetailView, self).get_context_data(**kwargs)
    context['course'] = Courses.objects.all().select_related("category")
    return context
4

1 回答 1

1

您必须过滤Courses模型以根据您的类别获取课程。

您必须在视图中使用类似的查询:

def get_context_data(self, **kwargs):
    context = super(CategoriesDetailView, self).get_context_data(**kwargs)
    context['course'] = Courses.objects.filter() # Your filter query here
    return context

现在您的过滤器查询可以基于kwargs您正在捕获的url.

如果您正在捕获 slug,您的过滤器查询将是:

slug = self.kwargs.get('slug')
# assuming that you've a field called slug in Category model
Courses.objects.filter(category__slug=slug) 
于 2019-07-19T03:56:10.693 回答