首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何限制在ForeignKey/ManyToMany Wagtail ModelAdmin字段中显示的项?

在 Wagtail 的 ModelAdmin 中,可以通过重写 get_queryset 方法来限制在 ForeignKey/ManyToMany 字段中显示的项。

对于 ForeignKey 字段,可以使用 limit_choices_to 参数来指定限制条件。例如,假设有一个 Author 模型和一个 Book 模型,Book 模型有一个 author 字段,可以通过以下方式限制 author 字段中显示的选项:

代码语言:txt
复制
from django.db import models
from wagtail.contrib.modeladmin.options import ModelAdmin, modeladmin_register
from myapp.models import Book

class BookAdmin(ModelAdmin):
    model = Book
    menu_label = 'Books'
    menu_icon = 'book'
    menu_order = 200
    add_to_settings_menu = False
    exclude_from_explorer = False
    list_display = ('title', 'author')

    def get_queryset(self, request):
        qs = super().get_queryset(request)
        # 限制 author 字段中只显示姓氏为 "Smith" 的作者
        qs = qs.filter(author__last_name='Smith')
        return qs

modeladmin_register(BookAdmin)

对于 ManyToMany 字段,可以使用 formfield_for_manytomany 方法来限制显示的选项。例如,假设有一个 Book 模型有一个 authors 字段,可以通过以下方式限制 authors 字段中显示的选项:

代码语言:txt
复制
from django.db import models
from wagtail.contrib.modeladmin.options import ModelAdmin, modeladmin_register
from myapp.models import Book

class BookAdmin(ModelAdmin):
    model = Book
    menu_label = 'Books'
    menu_icon = 'book'
    menu_order = 200
    add_to_settings_menu = False
    exclude_from_explorer = False
    list_display = ('title', 'authors')

    def formfield_for_manytomany(self, db_field, request, **kwargs):
        if db_field.name == 'authors':
            # 限制 authors 字段中只显示姓氏为 "Smith" 的作者
            kwargs['queryset'] = db_field.remote_field.model.objects.filter(last_name='Smith')
        return super().formfield_for_manytomany(db_field, request, **kwargs)

modeladmin_register(BookAdmin)

以上示例中,get_queryset 方法和 formfield_for_manytomany 方法都用于限制显示的选项,可以根据具体需求进行修改。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Django学习笔记之Queryset详解

    Django ORM用到三个类:Manager、QuerySet、Model。Manager定义表级方法(表级方法就是影响一条或多条记录的方法),我们可以以models.Manager为父类,定义自己的manager,增加表级方法;QuerySet:Manager类的一些方法会返回QuerySet实例,QuerySet是一个可遍历结构,包含一个或多个元素,每个元素都是一个Model 实例,它里面的方法也是表级方法,前面说了,Django给我们提供了增加表级方法的途径,那就是自定义manager类,而不是自定义QuerySet类,一般的我们没有自定义QuerySet类的必要;django.db.models模块中的Model类,我们定义表的model时,就是继承它,它的功能很强大,通过自定义model的instance可以获取外键实体等,它的方法都是记录级方法(都是实例方法,貌似无类方法),不要在里面定义类方法,比如计算记录的总数,查看所有记录,这些应该放在自定义的manager类中。以Django1.6为基础。

    03
    领券