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

时间:2010-08-12 16:43:34

标签: django django-admin override widget

我有一个自定义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小部件呈现。

非常感谢任何帮助。

-
OMAT

4 个答案:

答案 0 :(得分: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无法处理此问题)

答案 1 :(得分: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 :(得分: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小部件。

答案 3 :(得分:0)

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

  

Django 2.1.7

\n
class ProjectAdminForm(forms.ModelForm):
    class Meta:
        model = Project
        fields = '__all__'
        widgets = {
            'project_description': forms.Textarea(attrs={'cols': 98})
        }

谢谢@MuratÇorlu