【问题标题】:Filtering a django-tables2 table with django-filters using a drop down list使用下拉列表过滤带有 django-filters 的 django-tables2 表
【发布时间】:2018-05-18 22:02:12
【问题描述】:

我有一个模型(简要),我在 Django-tables2 的列表中显示。 Brief 可以属于一个或多个塔。我正在尝试创建一个视图,用户可以在其中查看所有简报,然后过滤以查找与特定塔相关的简报。我首先使用复选框实现了这一点,它正在工作,但我需要将该过滤器放入下拉列表中。

“GET /brief/?towers= HTTP/1.1” - 给我所有的简报。 “GET /brief/?towers=1 HTTP/1.1” - 给出一个空的简报列表。(应该在我的测试数据中给我 2 个) 在 django shell 中查询可以得到我期望的结果。

另一个奇怪的行为是我的下拉列表中有可以选择的空格。

class Attribute(models.Model):

    class Meta:
        abstract = True
        ordering = ['name']

    name = models.CharField(max_length=100, unique=True)
    created_on = models.DateTimeField(auto_now_add=True)
    created_by = models.ForeignKey(User, related_name='% 
       (class)s_created_by', null=True, blank=True, 
           on_delete=models.SET_NULL)
    modified_dt = models.DateTimeField(auto_now=True)
    modified_by = models.ForeignKey(User, related_name='% 
       (class)s_modified_by', null=True, blank=True, 
           on_delete=models.SET_NULL)

    def __str__(self):
        return self.name


class Tower(Attribute):
    pass


class Brief (Attribute):
   link = models.URLField()
   sources = models.ManyToManyField(SourceSystem)
   format = models.ForeignKey(ReportFormat, on_delete=models.PROTECT)
   towers = models.ManyToManyField(Tower)
   type = models.ForeignKey(ReportType, on_delete=models.PROTECT)
   project = models.ForeignKey(Project, on_delete=models.PROTECT)

   def tower_list(self):
      return ", ".join([str(obj) for obj in self.towers.all()])

   def source_list(self):
      return ", ".join([str(obj) for obj in self.sources.all()])

我的表.py:

class BriefTable(tables.Table):
    name = tables.LinkColumn('brief_detail', args=[A('pk')])

    class Meta:
        model = Brief
        template_name = 'django_tables2/bootstrap.html'
        sequence = ('id', 'name', 'type', 'project', 'format',)
        exclude = ('link', 'created_on', 'created_by', 'modified_dt', 'modified_by', 'info')

我的过滤器.py

class BriefFilter(django_filters.FilterSet):
    towers=django_filters.ModelMultipleChoiceFilter(
        queryset=Tower.objects.all(), widget=forms.Select)
    class Meta:
        model = Brief
        fields = ['towers']

我的看法:

class FilteredBriefListView(LoginRequiredMixin, SingleTableMixin, 
    FilterView):
    table_class = BriefTable
    template_name = 'brief/brief_list.html'
    paginate_by = 20
    filterset_class = BriefFilter

终于找到我的路线了:

urlpatterns = [
    path('', FilteredBriefListView.as_view(), name="home"),
]

【问题讨论】:

    标签: python django django-tables2 django-filters


    【解决方案1】:

    稍作休息后,我意识到我正在使用带有单一选择的 ModelMultipleChoiceFilter,而不是 ModelChoiceFilter.../facepalm。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-04-09
      • 2013-11-04
      • 2020-11-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多