我最近实现了 Ofri 提到的解决方案,因为我只想接受一个单独的“评论”字段作为评论(就像 SO 所做的那样,没有“名称”,没有“电子邮件”,也没有“url”)。
为了自定义默认的评论表单和列表显示,我在根“templates”目录中创建了一个“comments”目录,并覆盖了两个默认的评论模板。
我的“/templates/comments/form.html”是:
{% load comments i18n %}
{% if user.is_authenticated %}
<form action="{% comment_form_target %}" method="post">
{% csrf_token %}
{% if next %}<input type="hidden" name="next" value="{{ next }}" />{% endif %}
{% for field in form %}
{% if field.is_hidden %}
{{ field }}
{% else %}
{% if field.name != "name" and field.name != "email" and field.name != "url" %}
{% if field.errors %}{{ field.errors }}{% endif %}
<p {% if field.errors %} class="error"{% endif %} {% ifequal field.name "honeypot" %} style="display:none;"{% endifequal %}>
{{ field }}
</p>
{% endif %}
{% endif %}
{% endfor %}
<input type="submit" name="post" class="submit-post" value="{% trans "Add Comment" %}" />
</form>
{% else %}
I'm sorry, but you must be <a href="javascript:alert('send to login page')">logged in</a> to submit comments.
{% endif %}
这与默认的评论表单略有不同,主要是抑制不需要的“名称”、“电子邮件”和“网址”输入的显示。
我的“/templates/comments/list.html”是:
<div class="comment_start"></div>
{% for comment in comment_list %}
<div class="comment">
{{ comment.comment }}
(from <a href="javascript:alert('show user profile/stats')">{{ comment.user }}</a> - {{ comment.submit_date|timesince }} ago)
</div>
{% endfor %}
在我想要表格的页面上,我首先调用{% load comments %}
进而{% render_comment_form for [object] %
} 显示表格,或者{% render_comment_list for [object] %}
生成对象上的注释列表(将 [object] 替换为适当的对象名称)。
这对我来说非常有用,并且仍然为我提供了 django 评论附带的所有其他“免费”内容(审核、标记、提要、多态关联等......)