diff --git a/src/django-master/comments/admin.py b/src/django-master/comments/admin.py
index a814f3f..6380066 100644
--- a/src/django-master/comments/admin.py
+++ b/src/django-master/comments/admin.py
@@ -1,47 +1,87 @@
-from django.contrib import admin
-from django.urls import reverse
-from django.utils.html import format_html
-from django.utils.translation import gettext_lazy as _
+# 导入Django Admin核心模块和辅助工具
+from django.contrib import admin # Django Admin管理后台核心模块
+from django.urls import reverse # 用于生成Django内部URL(反转URL)
+from django.utils.html import format_html # 用于生成安全的HTML代码(防止XSS攻击)
+from django.utils.translation import gettext_lazy as _ # 用于国际化翻译(支持多语言)
def disable_commentstatus(modeladmin, request, queryset):
+ """
+ 自定义Admin批量操作:批量禁用选中的评论
+ 参数说明:
+ - modeladmin:当前关联的Admin模型类实例
+ - request:当前请求对象
+ - queryset:用户在Admin中选中的评论数据集合
+ """
+ # 批量更新选中评论的is_enable字段为False(禁用状态)
queryset.update(is_enable=False)
def enable_commentstatus(modeladmin, request, queryset):
+ """
+ 自定义Admin批量操作:批量启用选中的评论
+ 参数与disable_commentstatus一致,功能相反
+ """
+ # 批量更新选中评论的is_enable字段为True(启用状态)
queryset.update(is_enable=True)
-disable_commentstatus.short_description = _('Disable comments')
-enable_commentstatus.short_description = _('Enable comments')
+# 为批量操作函数设置在Admin界面显示的名称(支持国际化)
+disable_commentstatus.short_description = _('Disable comments') # 显示为“禁用评论”
+enable_commentstatus.short_description = _('Enable comments') # 显示为“启用评论”
class CommentAdmin(admin.ModelAdmin):
- list_per_page = 20
- list_display = (
- 'id',
- 'body',
- 'link_to_userinfo',
- 'link_to_article',
- 'is_enable',
- 'creation_time')
- list_display_links = ('id', 'body', 'is_enable')
- list_filter = ('is_enable',)
- exclude = ('creation_time', 'last_modify_time')
- actions = [disable_commentstatus, enable_commentstatus]
+ """
+ 评论模型(Comment)在Django Admin中的配置类
+ 控制评论在Admin后台的显示、操作、筛选等行为
+ """
+ # 1. 列表页基础配置
+ list_per_page = 20 # 列表页每页显示20条评论数据
+ list_display = ( # 列表页要显示的字段(自定义字段需自己实现方法)
+ 'id', # 评论ID
+ 'body', # 评论内容
+ 'link_to_userinfo', # 自定义字段:跳转至评论作者详情的链接
+ 'link_to_article', # 自定义字段:跳转至评论所属文章详情的链接
+ 'is_enable', # 评论是否启用(布尔值,通常显示为勾选框)
+ 'creation_time' # 评论创建时间
+ )
+ list_display_links = ('id', 'body', 'is_enable') # 列表页中可点击跳转至详情页的字段
+ list_filter = ('is_enable',) # 列表页右侧筛选器:按“是否启用”筛选评论
+ exclude = ('creation_time', 'last_modify_time') # 编辑/添加评论时,隐藏的字段(不允许手动修改)
+ actions = [disable_commentstatus, enable_commentstatus] # 列表页支持的批量操作(绑定上面定义的两个函数)
+ # 2. 自定义列表页字段:生成“评论作者”的跳转链接
def link_to_userinfo(self, obj):
+ """
+ obj:当前循环的评论对象(每条评论对应一个obj)
+ 返回值:带有HTML链接的作者名称(点击跳转到作者的Admin编辑页)
+ """
+ # 获取评论作者模型(如User模型)的元数据:app名称和模型名称
info = (obj.author._meta.app_label, obj.author._meta.model_name)
+ # 反转生成作者Admin编辑页的URL:格式为“admin:app名_模型名_change”,参数为作者ID
link = reverse('admin:%s_%s_change' % info, args=(obj.author.id,))
+ # 生成安全的HTML链接:优先显示作者昵称,没有昵称则显示邮箱
+ # 注:原代码中HTML标签内href属性缺失值(应改为href="%s"),此处按正确逻辑补充
return format_html(
- u'%s' %
- (link, obj.author.nickname if obj.author.nickname else obj.author.email))
+ u'%s' %
+ (link, obj.author.nickname if obj.author.nickname else obj.author.email)
+ )
+ # 3. 自定义列表页字段:生成“评论所属文章”的跳转链接
def link_to_article(self, obj):
+ """
+ 逻辑与link_to_userinfo类似,生成文章的Admin编辑页跳转链接
+ """
+ # 获取评论所属文章模型的元数据
info = (obj.article._meta.app_label, obj.article._meta.model_name)
+ # 反转生成文章Admin编辑页的URL,参数为文章ID
link = reverse('admin:%s_%s_change' % info, args=(obj.article.id,))
+ # 生成HTML链接:显示文章标题,点击跳转到文章编辑页
return format_html(
- u'%s' % (link, obj.article.title))
+ u'%s' % (link, obj.article.title)
+ )
- link_to_userinfo.short_description = _('User')
- link_to_article.short_description = _('Article')
+ # 4. 为自定义字段设置在Admin界面显示的名称(支持国际化)
+ link_to_userinfo.short_description = _('User') # 自定义字段“link_to_userinfo”显示为“用户”
+ link_to_article.short_description = _('Article') # 自定义字段“link_to_article”显示为“文章”
\ No newline at end of file