下面是一个模型示例:
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)
我现在有过滤器book
和chapter
用于exercise
.当我单击过滤器book
中的book
时,它会相应地向我显示所选book
的所有exercises
。但是在过滤器chapter
列表中,它仍然显示了所有books
的所有chapters
。
有没有办法在过滤器chapter
中仅显示我在第一个过滤器book
中选择的book
的chapters
?如何?
我不确定这是否是最好的方法,但在这里我使用管理面板中网址的 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))