Django 管理员显示过滤器取决于其他过滤器



下面是一个模型示例:

class Books(models.Model):
    ...
class Chapter(models.Model):
    ... 
    book = models.ForeignKey('Books')
class Exercise(models.Model):
    ...
    book = models.ForeignKey('Books')
    chapter = models.ForeignKey('Chapter') 

这是用于练习的 Admin 类:

class ExerciseAdmin(admin.ModelAdmin):
   ...
   list_filter = (('book',admin.RelatedOnlyFieldListFilter),('chapter',admin.RelatedOnlyFieldListFilter))
admin.site.register(Exercise, ExerciseAdmin)

我现在有过滤器bookchapter用于exercise.当我单击过滤器book中的book时,它会相应地向我显示所选book的所有exercises。但是在过滤器chapter列表中,它仍然显示了所有books的所有chapters

有没有办法在过滤器chapter中仅显示我在第一个过滤器book中选择的bookchapters?如何?

我不确定这是否是最好的方法,但在这里我使用管理面板中网址的 GET 参数来获取书籍的 ID,然后我可以选择相应的章节。它有效!

class ChapterFilter(admin.SimpleListFilter):
    title = 'chapter' 
    parameter_name = 'chapter'
    def lookups(self, request, model_admin):
        if 'book__id__exact' in request.GET:
            id = request.GET['book__id__exact']
            chapters = set([c.chapter for c in model_admin.model.objects.all().filter(book=id)])
        else:
            chapters = set([c.chapter for c in model_admin.model.objects.all()])
        return [(b.id, b.titre) for b in chapters]
    def queryset(self, request, queryset):
        if self.value():
            return queryset.filter(chapter__id__exact=self.value())
class ExerciseAdmin(admin.ModelAdmin):
   list_filter = (('book',admin.RelatedOnlyFieldListFilter), (ChapterFilter))

您是否从管理文档中查看过这个 https://docs.djangoproject.com/en/1.10/ref/contrib/admin/#django.contrib.admin.ModelAdmin.list_filter 使用简单列表过滤器

此线程中的示例...在 Django Admin 中为 list_filter创建自定义过滤器

在这里猜测...

from django.contrib.admin import SimpleListFilter
class ChapterFilter(SimpleListFilter):
   title = 'chapter' 
   parameter_name = 'chapter'
   def lookups(self, request, model_admin):
       chapters = set([c.book for c in model_admin.model.objects.all()])
       return [(b.id, b.name) for b in chapters]
   def queryset(self, request, queryset):
       if self.value():
           return queryset.filter(book__id__exact=self.value())
class BookAdmin(ModelAdmin):
    list_filter = (('book',admin.RelatedOnlyFieldListFilter), (ChapterFilter))

最新更新