如何在Django管理界面中换行文本(设置列宽)
我有一个模型叫做 Item
class Item(models.Model):
id = models.IntegerField(primary_key=True)
title = models.CharField(max_length=140, blank=True)
description = models.TextField(blank=True)
price = models.DecimalField(max_digits=12, decimal_places=2, blank=True, null=True)
还有我的模型管理
class ItemAdmin(admin.ModelAdmin):
list_display = ['item_view', 'description', 'item_price', 'seller_view', 'added_on']
actions = ['add_to_staff_picks']
search_fields = ('description', 'title')
def item_view(self, obj):
item = obj
url = reverse('admin:%s_%s_change' % ('adminuser', 'item'), args=(item.id,))
if item.is_active:
return '<font color="green">%s</font>' % (base64.b64decode(item.title))
return '<font color="red">%s</font>' % (base64.b64decode(item.title))
item_view.allow_tags = True
item_view.short_description = 'Title'
我需要在我的 Django 管理网站上显示 'title' 字段,并且想要给这个标题列设置一个固定的宽度。请问我该怎么做?求帮助。
4 个回答
0
替代答案
list_display = ('title_name', 'description',)
def title_name(self, obj):
if obj.tracking_no:
line_length = 20
lines = [obj.title[i:i+line_length] + '\n' for i in range(0, len(obj.title), line_length)]
return ''.join(lines)
return obj.title_name
track.short_description = "title"
1
这是一个使用HTML的答案。你可以把这个作为方法添加到你的 ModelAdmin
类里:
def title_(self, obj):
from django.utils.html import format_html
return format_html(
f'<div style="width: 100px; word-wrap: break-word">{obj.title}</div>'
)
然后在你的 list_display
声明中,把 title_
加进去,而不是 title
。
3
在你的 Model
里添加一个函数,然后在 modelAdmin
中调用这个函数。
#Model
def shortTitle(self):
return str(self.title)[:50]
#modelAdmin
class ItemAdmin(admin.ModelAdmin):
list_display = ['shortTitle', ...
2
如果我理解得没错,你需要的是Django管理类中的list_display
属性。
示例 "admin.py"
from django.contrib import admin
from path.to.your.app.models import Item
class ItemAdmin(admin.ModelAdmin):
"""
Your ``Item`` model admin.
"""
# List here all the fields that are to be displayed in the listing view.
list_display = ('title', 'description',)
admin.site.register(Item, ItemAdmin)
更新的回答 (2014-08-08)
- 可以查看这个 链接
你的管理模块:
from django.conf import settings
class ItemAdmin(admin.ModelAdmin):
# Some other code
class Media:
js = (
'{0}js/jquery-1.10.2.min.js'.format(settings.STATIC_URL),
'{0}js/jquery.expander.min.js'.format(settings.STATIC_URL),
'{0}your_app/js/your_code.js'.format(settings.STATIC_URL),
)
假设我们要使用jquery.expander插件 https://github.com/kswedberg/jquery-expander
那么你的 "your_code.js" 文件看起来会是这样的:
;
$(document).ready(function() {
// Assuming that your element that would be wrapped comes as second td (column).
// If not, adjst the nth-child(2).
$('#result_list tbody tr td:nth-child(2)').each(function(e) {
$(this).expander({
slicePoint: 50, // default is 100
expandSpeed: 0,
expandEffect: 'show',
collapseSpeed: 0,
collapseEffect: 'hide',
expandPrefix: ' ', // default is '... '
expandText: '[...]', // default is 'read more'
userCollapseText: '[^]' // default is 'read less'
});
});
});