Django Admin - 覆盖自定义表单字段的小部件

问题描述 投票:27回答:4

我有一个自定义TagField表单字段。

class TagField(forms.CharField):
    def __init__(self, *args, **kwargs):
        super(TagField, self).__init__(*args, **kwargs)
        self.widget = forms.TextInput(attrs={'class':'tag_field'})

如上所示,它使用TextInput表单字段小部件。但在管理员中我希望它使用Textarea小部件显示。为此,有formfield_overrides钩子,但它不适用于这种情况。

管理声明是:

class ProductAdmin(admin.ModelAdmin):
    ...
    formfield_overrides = {
        TagField: {'widget': admin.widgets.AdminTextareaWidget},
    }

这对表单字段小部件没有影响,tags仍然使用TextInput小部件呈现。

任何帮助深表感谢。

- 自己

django django-admin override widget
4个回答
45
投票

django管理员为其许多字段使用自定义小部件。覆盖字段的方法是创建一个与ModelAdmin对象一起使用的Form。

# forms.py

from django import forms
from django.contrib import admin

class ProductAdminForm(forms.ModelForm):
    def __init__(self, *args, **kwargs):
        super(ProductAdminForm, self).__init__(*args, **kwargs)
        self.fields['tags'].widget = admin.widgets.AdminTextareaWidget()

然后,在ModelAdmin对象中,指定表单:

from django.contrib import admin
from models import Product
from forms import ProductAdminForm

class ProductAdmin(admin.ModelAdmin):
    form = ProductAdminForm

admin.site.register(Product, ProductAdmin)

您还可以在此时覆盖查询集:例如,根据模型中的其他字段过滤对象(因为limit_choices_to无法处理此问题)


34
投票

您可以通过扩展自Django 1.2以来的ModelForm Meta类来覆盖字段小部件:

class ProductAdminForm(forms.ModelForm):
    class Meta:
        model = Product
        widgets = {
            'tags': admin.widgets.AdminTextareaWidget
        }

class ProductAdmin(admin.ModelAdmin):
    form = ProductAdminForm

https://docs.djangoproject.com/en/dev/topics/forms/modelforms/#overriding-the-default-fields


2
投票

尝试更改您的字段,如下所示:

class TagField(forms.CharField):
    def __init__(self, *args, **kwargs):
        self.widget = forms.TextInput(attrs={'class':'tag_field'})
        super(TagField, self).__init__(*args, **kwargs)

这将允许使用来自**kwargs的小部件。否则,您的字段将始终使用form.TextInput小部件。


0
投票

对于特定字段而不是我使用的字段:

Django 2.1.7

class ProjectAdminForm(forms.ModelForm):
    class Meta:
        model = Project
        fields = '__all__'
        widgets = {
            'project_description': forms.Textarea(attrs={'cols': 98})
        }
class ProjectAdmin(admin.ModelAdmin):
    form = ProjectAdminForm

谢谢,@MuratÇorlu

© www.soinside.com 2019 - 2024. All rights reserved.