====== 自定义评论列表区域 ====== ===== 一、自定义单条评论的HTML代码 ===== 在自定义评论前,我们得先设计好单条评论的 HTML 代码结构,如:
  • 评论时间 回复按钮

    我是评论内容

  • 自定义好HTML代码后,将如何去实现呢?首先我们要打开模板文件夹里的 comments.php 文件,做好修改准备。 ===== 二、使用自定义评论函数 ===== 打开 comments.php 文件后,我们需要在它的顶部,插入以下函数代码: authorId) { if ($comments->authorId == $comments->ownerId) { $commentClass .= ' comment-by-author'; //如果是文章作者的评论添加 .comment-by-author 样式 } else { $commentClass .= ' comment-by-user'; //如果是评论作者的添加 .comment-by-user 样式 } } $commentLevelClass = $comments->_levels > 0 ? ' comment-child' : ' comment-parent'; //评论层数大于0为子级,否则是父级 ?> /* 自定义评论的代码结构 */ 其次,将我们刚才自定义好的单条评论的 HTML 代码,放在上面代码里注释的地方,如下: authorId) { if ($comments->authorId == $comments->ownerId) { $commentClass .= ' comment-by-author'; //如果是文章作者的评论添加 .comment-by-author 样式 } else { $commentClass .= ' comment-by-user'; //如果是评论作者的添加 .comment-by-user 样式 } } $commentLevelClass = $comments->_levels > 0 ? ' comment-child' : ' comment-parent'; //评论层数大于0为子级,否则是父级 ?> /* 自定义评论的代码结构 */
  • 评论时间 回复按钮

    我是评论内容

  • ===== 三、用系统的评论变量替换HTML中相关属性 ===== 把 HTML 里相关的属性,替换成 typecho 系统中的评论变量,变量的列表可以参考下面。下面的例子,是替换评论的 id:
  • /* 替换后 */
  • 其中,替换ID这里,还需要判断判断当前评论是父级评论还是子级评论,且判断评论 ID 的奇偶数等。 ===== 四、添加嵌套评论(子评论) ===== 替换前:
    替换后后如下: children) { ?> //是否嵌套评论判断开始
    threadedComments($options); ?> //嵌套评论所有内容
    //是否嵌套评论判断结束
    ===== 五、相关变量及说明 ===== gravatar('40', ''); ?> //头像,有两个参数,大小、默认头像? author(); ?> //评论作者 permalink(); ?> //当前评论的连接地址 date('Y-m-d H:i'); ?>//评论时间,可在括号里设置格式 reply(); ?> //回复按钮,可在括号里自定义评论按钮的文字 content(); ?> //评论内容 ===== 六、最终得到的代码 ===== 当我们把上面所有变量都替换完成之后,最终得到的代码如下: authorId) { if ($comments->authorId == $comments->ownerId) { $commentClass .= ' comment-by-author'; } else { $commentClass .= ' comment-by-user'; } } $commentLevelClass = $comments->levels > 0 ? ' comment-child' : ' comment-parent'; ?>
  • gravatar('40', ''); ?> author(); ?>
    date('Y-m-d H:i'); ?> reply(); ?>
    content(); ?>
    children) { ?>
    threadedComments($options); ?>
  • **注意:**上面的自定义评论代码输出的,就是本来评论页里的下面这段代码,所以你就不用对这段代码做任何更改了。 listComments(); ?> 最新版本更新:首次评论审核提示,在自定义评论代码的适当地方添加以下语句,否则将看不到审核提示语句。 commentStatus(); ?>