我有
class Cab(models.Model):
name = models.CharField( max_length=20 )
descr = models.CharField( max_length=2000 )
class Cab_Admin(admin.ModelAdmin):
ordering = ('name',)
list_display = ('name','descr', )
# what to write here to make descr using TextArea?
admin.site.register( Cab, Cab_Admin )
如何在管理界面中将TextArea小部件分配给'descr'字段?
UPD:
仅在管理界面中!
使用ModelForm的好主意。
答案 0 :(得分:86)
您必须创建一个forms.ModelForm
来描述您希望如何显示descr
字段,然后告诉admin.ModelAdmin
使用该表单。例如:
from django import forms
class CabModelForm( forms.ModelForm ):
descr = forms.CharField( widget=forms.Textarea )
class Meta:
model = Cab
class Cab_Admin( admin.ModelAdmin ):
form = CabModelForm
form
的{{1}}属性记录在Django官方文档中。这是one place to look at。
答案 1 :(得分:49)
对于这种情况,最好的选择可能只是在模型中使用TextField而不是CharField。您还可以覆盖formfield_for_dbfield
类的ModelAdmin
方法:
class CabAdmin(admin.ModelAdmin):
def formfield_for_dbfield(self, db_field, **kwargs):
formfield = super(CabAdmin, self).formfield_for_dbfield(db_field, **kwargs)
if db_field.name == 'descr':
formfield.widget = forms.Textarea(attrs=formfield.widget.attrs)
return formfield
答案 2 :(得分:31)
class MessageAdminForm(forms.ModelForm):
class Meta:
model = Message
widgets = {
'text': forms.Textarea(attrs={'cols': 80, 'rows': 20}),
}
class MessageAdmin(admin.ModelAdmin):
form = MessageAdminForm
admin.site.register(Message, MessageAdmin)
因此,您不需要重新定义ModelForm中的字段来更改它的窗口小部件,只需在Meta中设置窗口小部件字典。
答案 3 :(得分:13)
您可以使用所需的formfield
方法对您自己的字段进行子类化:
class CharFieldWithTextarea(models.CharField):
def formfield(self, **kwargs):
kwargs.update({"widget": forms.Textarea})
return super(CharFieldWithTextarea, self).formfield(**kwargs)
这将对所有生成的表单产生影响。
答案 4 :(得分:6)
您不需要自己创建表单类:
from django.contrib import admin
from django import forms
class MyModelAdmin(admin.ModelAdmin):
def get_form(self, request, obj=None, **kwargs):
kwargs['widgets'] = {'descr': forms.Textarea}
return super().get_form(request, obj, **kwargs)
admin.site.register(MyModel, MyModelAdmin)
答案 5 :(得分:5)
如果您尝试在admin.py上更改Textarea,这是适合我的解决方案:
from django import forms
from django.contrib import admin
from django.db import models
from django.forms import TextInput, Textarea
from books.models import Book
class BookForm(forms.ModelForm):
description = forms.CharField( widget=forms.Textarea(attrs={'rows': 5, 'cols': 100}))
class Meta:
model = Book
class BookAdmin(admin.ModelAdmin):
form = BookForm
admin.site.register(Book, BookAdmin)
如果您使用的是MySQL数据库,您的列长度通常会自动设置为250个字符,因此您需要运行ALTER TABLE来更改MySQL数据库中的长度,以便您可以利用新的更大你在Admin Django网站上的Textarea。
答案 6 :(得分:3)
而不是models.CharField
,models.TextField
使用descr
。
答案 7 :(得分:3)
您可以将models.TextField
用于此目的:
class Sample(models.Model):
field1 = models.CharField(max_length=128)
field2 = models.TextField(max_length=1024*2) # Will be rendered as textarea
答案 8 :(得分:2)
希望扩展Carl Meyer的答案,该答案一直有效至今。
我总是使用TextField
而不是CharField
(有或没有选择)并在UI / API方面而不是在DB级别强加字符限制。为了使这项工作动态起作用:
from django import forms
from django.contrib import admin
class BaseAdmin(admin.ModelAdmin):
"""
Base admin capable of forcing widget conversion
"""
def formfield_for_dbfield(self, db_field, **kwargs):
formfield = super(BaseAdmin, self).formfield_for_dbfield(
db_field, **kwargs)
display_as_charfield = getattr(self, 'display_as_charfield', [])
display_as_choicefield = getattr(self, 'display_as_choicefield', [])
if db_field.name in display_as_charfield:
formfield.widget = forms.TextInput(attrs=formfield.widget.attrs)
elif db_field.name in display_as_choicefield:
formfield.widget = forms.Select(choices=formfield.choices,
attrs=formfield.widget.attrs)
return formfield
我的模型名称为Post
title
,slug
& state
为TextField
,state
有选择权。管理员定义如下:
@admin.register(Post)
class PostAdmin(BaseAdmin):
list_display = ('pk', 'title', 'author', 'org', 'state', 'created',)
search_fields = [
'title',
'author__username',
]
display_as_charfield = ['title', 'slug']
display_as_choicefield = ['state']
认为其他寻找答案的人可能会觉得这很有用。