# FRR:该模块定义了评论(Comment)数据模型,用于存储用户对文章的评论信息, # 包括评论内容、作者、关联文章、创建时间等字段,同时支持评论回复功能(父子评论关联)。 from django.conf import settings from django.db import models from django.utils.timezone import now # 用于获取当前时间 from django.utils.translation import gettext_lazy as _ # 用于国际化翻译 from blog.models import Article # 导入文章模型,建立评论与文章的关联 # FRR:评论模型类,继承自Django的Model基类,映射数据库中的评论表 class Comment(models.Model): # FRR:评论正文字段,TextField支持长文本,max_length限制最大长度为300字符 body = models.TextField('正文', max_length=300) # FRR:评论创建时间字段,默认值为当前时间,verbose_name用于后台显示的字段名(国际化) creation_time = models.DateTimeField(_('creation time'), default=now) # FRR:评论最后修改时间字段,默认值为当前时间,用于记录评论更新时间 last_modify_time = models.DateTimeField(_('last modify time'), default=now) # FRR:评论作者外键,关联Django内置的用户模型(settings.AUTH_USER_MODEL) # on_delete=models.CASCADE表示:若用户被删除,其评论也会被级联删除 author = models.ForeignKey( settings.AUTH_USER_MODEL, verbose_name=_('author'), on_delete=models.CASCADE) # FRR:关联的文章外键,评论属于某篇文章 # on_delete=models.CASCADE表示:若文章被删除,其下所有评论也会被级联删除 article = models.ForeignKey( Article, verbose_name=_('article'), on_delete=models.CASCADE) # FRR:父评论外键,实现评论回复功能(自关联) # 'self'表示关联自身模型,blank=True和null=True允许为空(即一级评论无父评论) # on_delete=models.CASCADE表示:若父评论被删除,其下所有子评论也会被级联删除 parent_comment = models.ForeignKey( 'self', verbose_name=_('parent comment'), blank=True, null=True, on_delete=models.CASCADE) # FRR:评论是否启用的状态字段,默认值为False(可能需要管理员审核后启用) # blank=False和null=False表示该字段为必填项,不允许为空 is_enable = models.BooleanField(_('enable'), default=False, blank=False, null=False) # FRR:Meta内部类用于配置模型的元数据 class Meta: ordering = ['-id'] # 数据查询时按id降序排列(最新评论在前) verbose_name = _('comment') # 模型的单数显示名称(国际化) verbose_name_plural = verbose_name # 模型的复数显示名称(与单数相同) get_latest_by = 'id' # 指定通过id字段获取最新记录 # FRR:定义模型实例的字符串表示,返回评论正文(便于在后台和调试时识别对象) def __str__(self): return self.body