评论

2017-04-1451170 阅读350 评论

创建评论应用

相对来说,评论其实是另外一个比较独立的功能。Django 提倡,如果功能相对比较独立的话,最好是创建一个应用,把相应的功能代码写到这个应用里。我们的第一个应用叫 blog,它里面放了展示博客文章列表和细节等相关功能的代码。而这里我们再创建一个应用,名为 comments,这里面将存放和评论功能相关的代码。首先激活虚拟环境,然后输入如下命令创建一个新的应用:

python manage.py startapp comments

我们可以看到生成的 comments 应用目录结构和 blog 应用的目录是类似的。关于创建应用以及 Django 的目录结构在 建立 Django 博客应用 中已经有过介绍。创建新的应用后一定要记得在 settings.py 里注册这个应用,Django 才知道这是一个应用。

blogproject/settings.py

...
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'blog',
    'comments', # 注册新创建的 comments 应用
]
...

设计评论的数据库模型

用户评论的数据必须被存储到数据库里,以便其他用户访问时 Django 能从数据库取回这些数据然后展示给访问的用户,因此我们需要为评论设计数据库模型,这和设计文章、分类、标签的数据库模型是一样的,如果你忘了怎么做,再回顾一下 创建 Django 博客的数据库模型 中的做法。我们的评论模型设计如下(评论模型的代码写在 comment\models.py 里):

comments/models.py

from django.db import models
from django.utils.six import python_2_unicode_compatible

# python_2_unicode_compatible 装饰器用于兼容 Python2
@python_2_unicode_compatible
class Comment(models.Model):
    name = models.CharField(max_length=100)
    email = models.EmailField(max_length=255)
    url = models.URLField(blank=True)
    text = models.TextField()
    created_time = models.DateTimeField(auto_now_add=True)

    post = models.ForeignKey('blog.Post')

    def __str__(self):
        return self.text[:20]

这里我们会保存评论用户的 name(名字)、email(邮箱)、url(个人网站),用户发表的内容将存放在 text 字段里,created_time 记录评论时间。最后,这个评论是关联到某篇文章(Post)的,由于一个评论只能属于一篇文章,一篇文章可以有多个评论,是一对多的关系,因此这里我们使用了 ForeignKey。关于 ForeKey 我们前面已有介绍,这里不再赘述。

同时注意我们为 DateTimeField 传递了一个 auto_now_add=True 的参数值。auto_now_add 的作用是,当评论数据保存到数据库时,自动把 created_time 的值指定为当前时间。created_time 记录用户发表评论的时间,我们肯定不希望用户在发表评论时还得自己手动填写评论发表时间,这个时间应该自动生成。

创建了数据库模型就要迁移数据库,迁移数据库的命令也在前面讲过。在虚拟环境下分别运行下面两条命令:

python manage.py makemigrations
python manage.py migrate

评论表单设计

这一节我们将学习一个全新的 Django 知识:表单。那么什么是表单呢?基本的 HTML 知识告诉我们,在 HTML 文档中这样的代码表示一个表单:

<form action="" method="post">
  <input type="text" name="username" />
  <input type="password" name="password" />
  <input type="submit" value="login" />
</form>

为什么需要表单呢?表单是用来收集并向服务器提交用户输入的数据的。考虑用户在我们博客网站上发表评论的过程。当用户想要发表评论时,他找到我们给他展示的一个评论表单(我们已经看到在文章详情页的底部就有一个评论表单,你将看到表单呈现给我们的样子),然后根据表单的要求填写相应的数据。之后用户点击评论按钮,这些数据就会发送给某个 URL。我们知道每一个 URL 对应着一个 Django 的视图函数,于是 Django 调用这个视图函数,我们在视图函数中写上处理用户通过表单提交上来的数据的代码,比如验证数据的合法性并且保存数据到数据库中,那么用户的评论就被 Django 后台处理了。如果通过表单提交的数据存在错误,那么我们把错误信息返回给用户,并在前端重新渲染,并要求用户根据错误信息修正表单中不符合格式的数据,再重新提交。

Django 的表单功能就是帮我们完成上述所说的表单处理逻辑,表单对 Django 来说是一个内容丰富的话题,很难通过教程中的这么一个例子涵盖其全部用法。因此我们强烈建议你在完成本教程后接下来的学习中仔细阅读 Django 官方文档关于 表单 的介绍,因为表单在 Web 开发中会经常遇到。

下面开始编写评论表单代码。在 comments 目录下(和 models.py 同级)新建一个 forms.py 文件,用来存放表单代码,我们的表单代码如下:

comments/forms.py

from django import forms
from .models import Comment


class CommentForm(forms.ModelForm):
    class Meta:
        model = Comment
        fields = ['name', 'email', 'url', 'text']

要使用 Django 的表单功能,我们首先导入 forms 模块。Django 的表单类必须继承自 forms.Form 类或者 forms.ModelForm 类。如果表单对应有一个数据库模型(例如这里的评论表单对应着评论模型),那么使用 ModelForm 类会简单很多,这是 Django 为我们提供的方便。之后我们在表单的内部类 Meta 里指定一些和表单相关的东西。model = Comment 表明这个表单对应的数据库模型是 Comment 类。fields = ['name', 'email', 'url', 'text'] 指定了表单需要显示的字段,这里我们指定了 name、email、url、text 需要显示。

关于表单进一步的解释

Django 为什么要给我们提供一个表单类呢?为了便于理解,我们可以把表单和前面讲过的 Django ORM 系统做类比。回想一下,我们使用数据库保存我们创建的博客文章,但是我们从头到尾没有写过任何和数据库有关的代码(要知道数据库自身也有一门数据库语言),这是因为 Django 的 ORM 系统内部帮我们做了一些事情。我们遵循 Django 的规范写的一些 Python 代码,例如创建 Post、Category 类,然后通过运行数据库迁移命令将这些代码反应到数据库。

Django 的表单和这个思想类似,正常的前端表单代码应该是和本文开头所提及的那样,但是我们目前并没有写这些代码,而是写了一个 CommentForm 这个 Python 类。通过调用这个类的一些方法和属性,Django 将自动为我们创建常规的表单代码,接下来的教程我们就会看到具体是怎么做的。

评论视图函数

当用户提交表单中的数据后,Django 需要调用相应的视图函数来处理这些数据,下面开始写我们视图函数处理逻辑:

comments/views.py

from django.shortcuts import render, get_object_or_404, redirect
from blog.models import Post

from .models import Comment
from .forms import CommentForm


def post_comment(request, post_pk):
    # 先获取被评论的文章,因为后面需要把评论和被评论的文章关联起来。
    # 这里我们使用了 Django 提供的一个快捷函数 get_object_or_404,
    # 这个函数的作用是当获取的文章(Post)存在时,则获取;否则返回 404 页面给用户。
    post = get_object_or_404(Post, pk=post_pk)

    # HTTP 请求有 get 和 post 两种,一般用户通过表单提交数据都是通过 post 请求,
    # 因此只有当用户的请求为 post 时才需要处理表单数据。
    if request.method == 'POST':
        # 用户提交的数据存在 request.POST 中,这是一个类字典对象。
        # 我们利用这些数据构造了 CommentForm 的实例,这样 Django 的表单就生成了。
        form = CommentForm(request.POST)

        # 当调用 form.is_valid() 方法时,Django 自动帮我们检查表单的数据是否符合格式要求。
        if form.is_valid():
            # 检查到数据是合法的,调用表单的 save 方法保存数据到数据库,
            # commit=False 的作用是仅仅利用表单的数据生成 Comment 模型类的实例,但还不保存评论数据到数据库。
            comment = form.save(commit=False)

            # 将评论和被评论的文章关联起来。
            comment.post = post

            # 最终将评论数据保存进数据库,调用模型实例的 save 方法
            comment.save()

            # 重定向到 post 的详情页,实际上当 redirect 函数接收一个模型的实例时,它会调用这个模型实例的 get_absolute_url 方法,
            # 然后重定向到 get_absolute_url 方法返回的 URL。
            return redirect(post)

        else:
            # 检查到数据不合法,重新渲染详情页,并且渲染表单的错误。
            # 因此我们传了三个模板变量给 detail.html,
            # 一个是文章(Post),一个是评论列表,一个是表单 form
            # 注意这里我们用到了 post.comment_set.all() 方法,
            # 这个用法有点类似于 Post.objects.all()
            # 其作用是获取这篇 post 下的的全部评论,
            # 因为 Post 和 Comment 是 ForeignKey 关联的,
            # 因此使用 post.comment_set.all() 反向查询全部评论。
            # 具体请看下面的讲解。
            comment_list = post.comment_set.all()
            context = {'post': post,
                       'form': form,
                       'comment_list': comment_list
                       }
            return render(request, 'blog/detail.html', context=context)
    # 不是 post 请求,说明用户没有提交数据,重定向到文章详情页。
    return redirect(post)

这个评论视图相比之前的一些视图复杂了很多,主要是处理评论的过程更加复杂。具体过程在代码中已有详细注释,这里仅就视图中出现了一些新的知识点进行讲解。

首先我们使用了 redirect 函数。这个函数位于 django.shortcuts 模块中,它的作用是对 HTTP 请求进行重定向(即用户访问的是某个 URL,但由于某些原因,服务器会将用户重定向到另外的 URL)。redirect 既可以接收一个 URL 作为参数,也可以接收一个模型的实例作为参数(例如这里的 post)。如果接收一个模型的实例,那么这个实例必须实现了 get_absolute_url 方法,这样 redirect 会根据 get_absolute_url 方法返回的 URL 值进行重定向。

另外我们使用了 post.comment_set.all() 来获取 post 对应的全部评论。 CommentPost 是通过 ForeignKey 关联的,回顾一下我们当初获取某个分类 cate 下的全部文章时的代码:Post.objects.filter(category=cate)。这里 post.comment_set.all() 也等价于 Comment.objects.filter(post=post),即根据 post 来过滤该 post 下的全部评论。但既然我们已经有了一个 Post 模型的实例 post(它对应的是 Post 在数据库中的一条记录),那么获取和 post 关联的评论列表有一个简单方法,即调用它的 xxx_set 属性来获取一个类似于 objects 的模型管理器,然后调用其 all 方法来返回这个 post 关联的全部评论。 其中 xxx_set 中的 xxx 为关联模型的类名(小写)。例如 Post.objects.filter(category=cate) 也可以等价写为 cate.post_set.all()

绑定 URL

视图函数需要和 URL 绑定,这里我们在 comment 应用中再建一个 urls.py 文件,写上 URL 模式:

comments/urls.py

from django.conf.urls import url

from . import views

app_name = 'comments'
urlpatterns = [
    url(r'^comment/post/(?P<post_pk>[0-9]+)/$', views.post_comment, name='post_comment'),
]

别忘了给这个评论的 URL 模式规定命名空间,即 app_name = 'comments'

最后要在项目的 blogprokect 目录的 urls.py 里包含 comments\urls.py 这个文件:

blogproject/urls.py

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'', include('blog.urls')),
    + url(r'', include('comments.urls')),
]

更新文章详情页面的视图函数

我们可以看到评论表单和评论列表是位于文章详情页面的,处理文章详情页面的视图函数是 detail,相应地需要更新 detail,让它生成表单和从数据库获取文章对应的评论列表数据,然后传递给模板显示:

blog/views.py

import markdown

from django.shortcuts import render, get_object_or_404

+ from comments.forms import CommentForm
from .models import Post, Category

def detail(request, pk):
    post = get_object_or_404(Post, pk=pk)
    post.body = markdown.markdown(post.body,
                                  extensions=[
                                      'markdown.extensions.extra',
                                      'markdown.extensions.codehilite',
                                      'markdown.extensions.toc',
                                  ])
    # 记得在顶部导入 CommentForm
    form = CommentForm()
    # 获取这篇 post 下的全部评论
    comment_list = post.comment_set.all()

    # 将文章、表单、以及文章下的评论列表作为模板变量传给 detail.html 模板,以便渲染相应数据。
    context = {'post': post,
               'form': form,
               'comment_list': comment_list
               }
    return render(request, 'blog/detail.html', context=context)

在前端渲染表单

使用 Django 表单的一个好处就是 Django 能帮我们自动渲染表单。我们在表单的视图函数里传递了一个 form 变量给模板,这个变量就包含了自动生成 HTML 表单的全部数据。在 detail.html 中通过 form 来自动生成表单。删掉原来用于占位的 HTML 评论表单代码,即下面这段代码:

<form action="#" method="post" class="comment-form">
  <div class="row">
    <div class="col-md-4">
      <label for="id_name">名字:</label>
      <input type="text" id="id_name" name="name" required>
    </div>
    ...
  </div>    <!-- row -->
</form>

替换成如下的代码:

<form action="{% url 'comments:post_comment' post.pk %}" method="post" class="comment-form">
  {% csrf_token %}
  <div class="row">
    <div class="col-md-4">
      <label for="{{ form.name.id_for_label }}">名字:</label>
      {{ form.name }}
      {{ form.name.errors }}
    </div>
    <div class="col-md-4">
      <label for="{{ form.email.id_for_label }}">邮箱:</label>
      {{ form.email }}
      {{ form.email.errors }}
    </div>
    <div class="col-md-4">
      <label for="{{ form.url.id_for_label }}">URL:</label>
      {{ form.url }}
      {{ form.url.errors }}
    </div>
    <div class="col-md-12">
      <label for="{{ form.text.id_for_label }}">评论:</label>
      {{ form.text }}
      {{ form.text.errors }}
      <button type="submit" class="comment-btn">发表</button>
    </div>
  </div>    <!-- row -->
</form>

{{ form.name }}、{{ form.email }}、{{ form.url }} 等将自动渲染成表单控件,例如 <input> 控件。

{{ form.name.errors }}、{{ form.email.errors }} 等将渲染表单对应字段的错误(如果有的话),例如用户 email 格式填错了,那么 Django 会检查用户提交的 email 的格式,然后将格式错误信息保存到 errors 中,模板便将错误信息渲染显示。

显示评论内容

在 detail 视图函数我们获取了全部评论数据,并通过 comment_list 传递给了模板。和处理 index 页面的文章列表方式是一样的,我们在模板中通过 {% for %} 模板标签来循环显示文章对应的全部评论内容。

删掉占位用的评论内容的 HTML 代码,即如下的代码:

<ul class="comment-list list-unstyled">
  <li class="comment-item">
    <span class="nickname">追梦人物</span>
    <time class="submit-date">2017年3月12日 14:56</time>
    <div class="text">
      文章观点又有道理又符合人性,这才是真正为了表达观点而写,不是为了迎合某某知名人士粉丝而写。我觉得如果琼瑶是前妻,生了三孩子后被一不知名的女人挖了墙角,我不信谁会说那个女人是追求真爱,说同情琼瑶骂小三的女人都是弱者。
    </div>
  </li>
  ...
</ul>

替换成如下的代码:

<ul class="comment-list list-unstyled">
  {% for comment in comment_list %}
  <li class="comment-item">
    <span class="nickname">{{ comment.name }}</span>
    <time class="submit-date">{{ comment.created_time }}</time>
    <div class="text">
      {{ comment.text }}
    </div>
  </li>
  {% empty %}
  暂无评论
  {% endfor %}
</ul>

接下来尝试在详情页下的评论表单提交一些评论数据,可以看到详情页的评论列表处渲染了你提交的评论数据。

评论列表

总结

本章节的代码位于:Step12: comments

如果遇到问题,请通过下面的方式寻求帮助。

-- EOF --

350 评论
登录后回复
王季勋
2019-09-10 16:19:37

博主你好,我的评论提交以后,无法在详情页显示。

因为没有报错,所以不知道从哪排查,不过我在admin添加评论可以显示。

回复
追梦人物 王季勋
2019-09-10 16:29:34

具体代码贴上来看下呢?

回复
王季勋 追梦人物
2019-09-10 18:09:45

谢谢博主,已经解决了。跟前面那个哥们一样,没进if里面去,request后少写了个mothed,所以评论保存不成功。

前面一直以为是模版出了问题,找了半天,哈哈。

谢谢博主啦!

回复
离人愁
2019-08-09 15:51:57

博主您好,编写评论模块时,提交评论后,页面跳转一个报错页面,‘127.0.0.1 未发送任何数据。’但是返回到详情页面后,发现评论成功了,而且同一条评论出现三条,这是什么原因呢?

回复
离人愁 离人愁
2019-08-09 16:02:30

在视图函数中把set_all()那句话放在上面就好了

def post_comment(request, post_pk): 

 post = get_object_or_404(Post, pk=post_pk) 

 comment_list = post.comment_set.all()

 if request.method == 'POST': form = CommentForm(request.POST)

回复
hoiwanchang
2019-07-29 00:36:57

评论显示不出来的问题我也遇到了,观察了一下发现是因为url导致的,但是不知道怎么处理

能显示出表单同时不能正确调用markdown的url是

http://127.0.0.1:8000/comment/post/2/

不显示出表单同时能正确调用markdown的url是

http://127.0.0.1:8000/post/2/

尝试过通过blog的url加载commets的view模块,但是报错

Exception Type:NoReverseMatch
Exception Value:Reverse for 'post_comment' with arguments '(2,)' and keyword arguments '{}' not found. 0 pattern(s) tried: []

才疏学浅,未能处理,请问博主应该怎么处理这个问题呢?

是不是将comments应用与blog应用合并更好处理这个问题?

回复
南南南南南极姑娘
2019-07-23 15:42:42

博主,评论表单如果只显示评论内容,不设置姓名、邮箱、url等,怎么在评论中关联发表评论的用户?我这边一直报错(1048, "Column 'author_id' cannot be null")

回复
hoiwanchang 南南南南南极姑娘
2019-07-28 22:35:19

感觉你的问题可以用发布文章那一节的思路来解决

comments/models.py里面

```

+ from django.contrib.auth.models import User

class Comment(models.Model):

    - name = models.CharField(max_length=100)

    + name = models.ForeignKey(User)

```

回复
losetemp
2019-05-27 17:13:23

122121

回复
losetemp losetemp
2019-05-27 17:13:49

test

回复
losetemp losetemp
2019-05-27 17:14:06

test again

回复
鸿标_weng
2019-05-14 18:06:57

博主,为什么做完这个评价之后detail就打不开了,变成A server error occurred. Please contact the administrator.而index,category,这些界面没问题,detail.html也没问题,然后尝试一个一个标签去排查,结果原本可以打开的detail界面加了代码再删除,跟原来一样却还不行,为什么啊,

回复
为梦而行521
2019-04-19 15:18:53

{% csrf_token %} <div class="row"> <div class="col-md-4"> <label for="{{ form.name.id_for_label }}">名字:</label> {{ form.name }} {{ form.name.errors }} </div> <div class="col-md-4"> <label for="{{ form.email.id_for_label }}">邮箱:</label> {{ form.email }} {{ form.email.errors }} </div> <div class="col-md-4"> <label for="{{ form.url.id_for_label }}">URL:</label> {{ form.url }} {{ form.url.errors }} </div> <div class="col-md-12"> <label for="{{ form.text.id_for_label }}">评论:</label> {{ form.text }} {{ form.text.errors }} <button type="submit" class="comment-btn">发表</button> </div>

按这部分写的,for=“”为空怎么解决

回复
为梦而行521
2019-04-19 15:14:55

AttributeError: 'CommentFormTest' object has no attribute 'name'

这个是怎么回事,给怎么解决,还有就是如果按博主的写法,for后为空

回复
OMGkillerMao
2019-03-28 14:11:00

  File "D:\BYSJ\blogproject_env\comment.py", line 4, in <module>    import xattrModuleNotFoundError: No module named 'xattr'

运行出现这个错误,然后我pip install xattr,出现下面的错误

  building '_lib' extension  error: Microsoft Visual C++ 14.0 is required. Get it with "Microsoft Visual C++ Build Tools": https://visualstudio.microsoft.com/downloads/

你们出现这个错误了么,C++14.0你们都下了?

回复
WinneYD
2019-02-28 17:00:48
class Comment(models.Model):    
    name=models.CharField(max_length=100)
    email=models.EmailField()
    url=models.URLField(blank=True)
    text=models.TextField()
    created_time=models.DateTimeField(auto_now_add=True)
    post=models.ForeignKey('blog.Post',on_delete='CASCADE')
    def __str__(self):        
      return self.text[:20]

请问关于评论的模型类,为什么不是返回整个text? return self.text[:20] 返回的评论最后20个应该不显示呀,可是实际界面显示的是全部的评论内容,这是为什么呢?

回复
追梦人物 WinneYD
2019-03-01 18:31:11

__str__ 返回的内容在管理台页面显示,内容太长显示不下来。

回复
WinneYD 追梦人物
2019-03-03 20:28:56

感谢博主

回复
wenxn
2019-02-12 15:08:44

你好 我想请教一下 删除评论的视图函数应该具备什么思路?我的想法是 先找出id对应的文章,然后能根据foreign key 找到评论,可是删除特定的评论呢?是还需要id么

回复
追梦人物 wenxn
2019-02-13 12:03:57

当然需要评论的 id 才能够对特定评论进行删除。

回复
尕孑茕煜
2019-02-01 13:02:42

博主啊,我把你的代码下载下来覆盖了我写的,但是输入框还是显示不出来啊,下面有一位大兄弟有同样的问题,但是他没给出确切的解决方法啊!

回复
追梦人物 尕孑茕煜
2019-02-11 12:13:29

打开 f12 调试一下呢?是不是表单写错了?

回复
为梦而行521 追梦人物
2019-04-19 16:56:09

我的也是啊

回复
ronething 尕孑茕煜
2019-05-28 18:28:06

```python

return render(request, 'blog/detail.html', context=context)

```

不知道你是不是忘记了文章的视图函数这里要 context=context

回复
Ljn367
2018-12-14 10:28:30

'MediaDefiningClass' object is not iterable.我这个问题什么原因呢?网上都没有找到相关的答案

回复
AbnerXia
2018-10-26 15:15:04

我照着谢了代码之后总是出现 No module named 'blogproject.comments'这个错误,然后我去网上问了下,添加了__init__.py文件也还是不行,我把导入的那句改成from ..comments.forms import CommentForm之后,错误又变成了attempted relative import beyond top-level package

回复
AbnerXia AbnerXia
2018-10-26 15:33:23

对了,我在导入的时候用的是from blogprodect.comments.forms import CommentForm

我把他改回博主上的代码后就行了,但是pycharm上导入那里显示红色的波浪线警告,这是为什么?

回复
TangZhonghan AbnerXia
2018-10-31 11:17:50

我刚刚做到这里也是有红色的波浪线警告,应该是Pycharm的问题

回复
追梦人物 AbnerXia
2018-11-24 17:05:11

更新一下 pycharm 的版本?pycharm 你在导包时会自动提示吗?

回复
ask8xm
2018-09-08 23:55:49

如果在新的版本上跑 python manage.py makemigrations出现以下的错误,是由于新的Django要求 ForeignKey 强制添加 on_delete 参数:

TypeError: __init__() missing 1 required positional argument: 'on_delete'

把 post = models.ForeignKey('blog.Post')  替换成  post = models.ForeignKey('blog.Post', on_delete=models.CASCADE)

回复
EdisonCV
2018-09-04 17:05:46

博主,我建立了评论的models的时候,迁移数据库一直报错,说ModuleNotFoundError: No module named 'blogcomments',但是我搜了我的项目,发现没有出现blogcomments啊。 Image


blogapp的models:

from django.db import modelsfrom django.contrib.auth.models import User# Create your models here.#分类class Category(models.Model): name = models.CharField(max_length=100) def __str__(self): return self.name#标签class Tag(models.Model): name = models.CharField(max_length=100) def __str__(self): return self.name#文章class Blog(models.Model): #标题 title = models.CharField(max_length=100) #文章内容 article = models.TextField() #发表时间 created_time = models.DateField() #修改时间 modified_time = models.DateField() #摘要 excerpt = models.CharField(max_length=200,blank=True) ''' ForeignKey 一对多关联 blank:True 表示参数可以为空 ''' #分类 category = models.ForeignKey(Category,on_delete=models.CASCADE) #标签 tag = models.ForeignKey(Tag,blank=True,on_delete=models.CASCADE) #作者 author = models.ForeignKey(User,on_delete=models.CASCADE) def __str__(self): return self.title

评论app的models:

from django.db import modelsfrom blog.models import Blog# Create your models here.class Comment(models.Model): #名字 name = models.CharField(max_length=100) #邮箱 email = models.EmailField(max_length=250) #网址 url = models.URLField(blank=True) #评论 text = models.TextField() #发表时间 created_time = models.DateTimeField(auto_now_add=True) #外键 post = models.ForeignKey('blog.Blog') def __str__(self): return self.text[:20]


博主可以帮我看看嘛?找了好久都找不到解决方法

回复
追梦人物 EdisonCV
2018-09-05 12:11:31

这个需要看一下你项目的目录结构才好说

回复
Xu Jianjun EdisonCV
2018-09-08 19:32:36

注册应用时是不是少了逗号

回复
zhaolizhi
2018-09-03 14:41:39

博主你好,为什么在`blog/views.py` 的 `detail`方法中,

`form = CommentForm()`不填入任何参数,而在`comments/views.py`的post_comment方法中,

`form = CommentForm(request.POST)`却填入参数呢?

两个form对象有什么异同吗?谢谢

回复
追梦人物 zhaolizhi
2018-09-05 12:14:03

第一个表单展示的是一个空表单,第二个表单绑定了前端post过来的数据,表单会对这些数据做验证,并保存数据到数据库

回复
曾用名杨北府
2018-08-29 22:53:29

博主你好,我的评论功能已经实现,但是detail.html始终报一个错,不知道为什么

 <div class="col-md-4">
                                 <label for="{{form.name.id_for_label}}">名字:</label>
                                {{form.name}}
                                {{form.name.errors}}
                            </div>

                            </div>

"{{form.name.id_for_label}}"报错This inspection checks for unresolved "id" attributes in XML.后几个也是

为什么会这样然后要怎么解决呢

回复
追梦人物 曾用名杨北府
2018-09-05 12:17:14

这应该是后端代码的问题,先通过控制台定位一下错误代码的地方。

回复
suxianglun
2018-08-21 10:18:39

博主你好,在评论这一块,提交了评论之后,数据并未保存到数据库中,发现命令行中报 GET/comment/static/js/script.js HTTP/1.1" 404 3154Not Found: /comment/static/js/script.js 这个错误, 我的

static/js/script.js是放在blog/static/js/script.js下面了,为什么会去/comment/static/js/script.js下加载这个js,是我哪里写错了吗,百思不得其解,还望博主能够指点迷津。

回复
追梦人物 suxianglun
2018-08-23 09:11:37

这个错误应该不影响你提交评论,你使用了 static 模板标签来引入静态文件吗?

回复
suxianglun 追梦人物
2018-08-23 09:20:21

谢谢博主大人能抽出宝贵时间回复,找到上述问题的原因了,是同一个静态文件引入了两次,第一个正确的,第二个是错误的,第二个把第一个覆盖了,所以就找不到了。这个问题解决了,但是评论提交后还是没有保存到数据库,我是用的mysql,没用sqlit ,Post请求也正常200,也没报错,目前还没找到原因。请博主大人给点查找问题的思路?或者告诉我一下Django项目如何打断点debug调试?小弟不胜感激

回复
Mirko suxianglun
2019-03-29 13:46:58

碰到了一样的问题,请问层主解决了吗?

回复
Mirko Mirko
2019-03-31 23:35:30

我的问题找到了,是视图函数的条件写错了,将`if request.method == 'POST':`的`'POST'`写成了`‘Post'`导致根本没有进入后续的条件判断中。

回复
xusanpang
2018-08-16 13:25:27

test

回复
Unreal_Lv
2018-08-10 17:03:31

博主你好,我跟着教程已经实现了评论的保存与展示,可是在admin管理台找不到对应的评论数据,请问在哪能看到?

回复
Unreal_Lv Unreal_Lv
2018-08-10 17:36:31

知道了,因为我忘记在comment的admin.py中注册对应的model了

回复
zzz Unreal_Lv
2018-09-15 17:35:21

请问怎么注册呢?

回复
zzz zzz
2018-09-15 22:50:54

奥,知道了,comments/admin.py 修改为以下内容

# comments/admin.py
from django.contrib import admin
from .models import Comment

# Register your models here.
admin.site.register(Comment)

回复
yukiyu4444
2018-08-07 16:11:16

博主您好,我打开详情页的时候出错了:


OperationalError at /post/1/

no such table: comments_comment


In template E:\jy\blog\blogproject\templates\blog\detail.html, error at line 53

no such table: comments_comment

53 {% for comment in comment_list %}

请问是什么原因呢?

回复
yukiyu4444 yukiyu4444
2018-08-07 16:24:27

解决了~

回复
城西王爷_689 yukiyu4444
2018-08-11 02:23:34

猜测:

1. 可能是因为代码中有写错comment单词,比如写成了commemt之类的

2. 可能是你的模型定义当中有错误,可以对照博主上面的内容检查一下

建议可以题主可以简单介绍一下你是如何解决的,可以给之后的人一点思路,谢谢

回复
Fredisfighting yukiyu4444
2018-08-16 14:38:34

能问一下你是怎么解决的吗,卡在这了。。。

回复
Fredisfighting Fredisfighting
2018-08-16 15:13:20

模型没有迁徙。。。

回复
纸巾的柔顺
2018-08-03 22:40:32

IntegrityError at /comment/post/3/NOT NULL constraint failed: comments_comment.port_id 

Request Method: POST 

Request URL: http://127.0.0.1:8000/comment/post/3/ 

Django Version: 1.10.5 

Exception Type: IntegrityErrorException Value: NOT NULL constraint failed: comments_comment.port_id

 Exception Location: F:\Program Files (x86)\Anaconda\lib\site-packages\django\db\backends\sqlite3\base.py in execute, line 337

 Python Executable: F:\Program Files (x86)\Anaconda\python.exePython Version: 3.6.5 

Python Path: ['E:\\Python\\blogproject',

  'F:\\Program Files (x86)\\Anaconda\\python36.zip', 'F:\\Program Files (x86)\\Anaconda\\DLLs',

  'F:\\Program Files (x86)\\Anaconda\\lib', 

 'F:\\Program Files (x86)\\Anaconda', 'F:\\Program Files (x86)\\Anaconda\\lib\\site-packages', 

 'F:\\Program Files (x86)\\Anaconda\\lib\\site-packages\\win32', 

 'F:\\Program Files (x86)\\Anaconda\\lib\\site-packages\\win32\\lib', 

 'F:\\Program Files (x86)\\Anaconda\\lib\\site-packages\\Pythonwin'] 

Server time: 星期五, 3 八月 2018 22:25:14 +0800

回复
纸巾的柔顺
2018-08-03 22:37:50


Image

回复
WinKingFace 纸巾的柔顺
2018-08-08 18:16:47

飒飒

回复
纸巾的柔顺
2018-08-03 22:36:05

IntegrityError at /comment/post/3/NOT NULL constraint failed: comments_comment.port_idRequest Method:POSTRequest URL:http://127.0.0.1:8000/comment/post/3/Django Version:1.10.5Exception Type:IntegrityErrorException Value:NOT NULL constraint failed: comments_comment.port_idException Location:F:\Program Files (x86)\Anaconda\lib\site-packages\django\db\backends\sqlite3\base.py in execute, line 337Python Executable:F:\Program Files (x86)\Anaconda\python.exePython Version:3.6.5Python Path:['E:\\Python\\blogproject', 'F:\\Program Files (x86)\\Anaconda\\python36.zip', 'F:\\Program Files (x86)\\Anaconda\\DLLs', 'F:\\Program Files (x86)\\Anaconda\\lib', 'F:\\Program Files (x86)\\Anaconda', 'F:\\Program Files (x86)\\Anaconda\\lib\\site-packages', 'F:\\Program Files (x86)\\Anaconda\\lib\\site-packages\\win32', 'F:\\Program Files (x86)\\Anaconda\\lib\\site-packages\\win32\\lib', 'F:\\Program Files (x86)\\Anaconda\\lib\\site-packages\\Pythonwin']Server time:星期五, 3 八月 2018 22:25:14 +0800


报这个错,不清楚那里出问题了,环境 和代码一直跟着打

回复
whyjust
2018-07-10 22:52:10

博主你好, 这么认真的博客教程我还是第一次见,超赞!!  对于评论这块我有个小小的问题,评论应该算是独立于博文展示的,是不是可以考虑用ajax局部刷新替代redirect ,用以提升用户体验呢?

回复
追梦人物 whyjust
2018-07-16 16:26:02

谢谢!可以这么做,但对于教程来说就不增加复杂度了。

回复
whyjust 追梦人物
2018-07-17 10:22:51

博主,Python后端这块Django,Flask都做过一些项目,但是后端有一定的局限性,最近在准备系统的往机器学习这块转,博主这块有了解么?博主是不是在校研啊?

回复
追梦人物 whyjust
2018-07-17 15:42:55

帮不了你了,我研究生也不是搞的机器学习。

回复
luohua13950
2018-07-03 16:50:54

一提交评论就出现Exception Value:argument of type 'Post' is not iterable,,,,,,是什么情况

回复
追梦人物 luohua13950
2018-07-17 15:45:13

你可能在某个地方迭代了 Post 这个类,显然是不行的。

回复
rsonghuster
2018-06-14 18:14:53

请问这个评论时候输入的url的意义是什么,存储到数据库中,但是不知道这个字段的意义

回复
ylllllllll__
2018-06-09 23:50:09

博主你好,请问为什么我输入‘’from blog.models import Post‘’时会报错no module named blog?我已经创建了一个名为blog的app了,app下有__init__.py文件。

回复
你好凯伦
2018-06-05 19:45:41

你好

我想问为什么发表评论后什么都显示不出来就卡在一个空白画面, 后台显示: Method Not Allowed (POST): /comment/post/5/    views.py中的post_comment函数完全没被调用

后面我直接把评论部分你的代码全部copyandpaste还是报这个 (不是显示)

回复
xinyuebaiyun
2018-05-26 09:50:46

 博主你好,还有个问题, 

comment=form.save(commit=False)

这行代码是把表单数据存入数据库,表单数据是'name','email','url','text‘吗?既然commit=False参数作用是用表单的数据生成 Comment 模型类的实例,为什么不是以生成的Comment 模型类的实例存入呢?还要用comment.save()保存评论数据呢?

琢磨了好久没理解

回复
追梦人物 xinyuebaiyun
2018-05-28 12:06:38

看代码注释,我们首先需要根据表单传过来的数据构造 Comment  模型类的实 comment,关键一步是要把评论和被评论的 post 关联,关联后才调用 comment.save() 方法真正地把数据存入数据库。

回复
xinyuebaiyun
2018-05-25 11:08:22

博主你好,

这个博客建好后,有用户注册/登入功能吗?

回复
追梦人物 xinyuebaiyun
2018-05-28 12:04:18

可以参考我的第二个教程,用户登录注册自己添加登录功能

回复
桀骜不驯镍铬合金
2018-05-22 21:25:34

博主你好, 我跟着您的教程走了一遍, 然后发表评论之后直接重定向到文章详情页, 但是评论并没有显示, 而且也没有保存到数据库当中, debug测试, 在comment_post当中设置断点, 然后发表文章还是直接刷新了页面, 好像直接就没有进到comments.views逻辑里面, 本来以为是代码细节写错了, 但是把评论相关的代码全部删了后一步步拷贝您的代码, 结果是一样的, 也不报错, 就是评论不能保存到数据库中, 我也没办法了, 请求博主帮我分析一下, 谢谢

回复
追梦人物 桀骜不驯镍铬合金
2018-05-23 12:11:16

 看看表单的 action 是否是 comments.views 的 URL。

回复
桀骜不驯镍铬合金 追梦人物
2018-05-23 12:37:57
detail.html
<h3>发表评论</h3>
                    <form action="{% url 'comments:post_comment' post.pk %}" method="post" class="comment-form">
                      {% csrf_token %}
comments/urls.py
from . import views


app_name = 'comments'
urlpatterns = [
    url(r'^comment/post/(?P<post_pk>[0-9]+)/$', views.post_comment, name='post_comment'),
]

没发现有什么错误

回复
追梦人物 桀骜不驯镍铬合金
2018-05-28 12:12:53

我怀疑是不是 if else 的缩进等导致逻辑变了,仔细对比一下和源码的区别,尤其是 if else 的逻辑

回复
桀骜不驯镍铬合金 追梦人物
2018-05-29 23:01:01

之前那个问题不知道怎么回事就变好了, 然后出了另一个问题, 主url中两个app的正则匹配不能同时为空, 不然发表评论后会报405错误, 因此我就把主url分别改成了以blog和comments为前缀的就好了, 我用的是django1.11.6和django3.6.3, 不知道老版本有没有这个问题.

回复
追梦人物 桀骜不驯镍铬合金
2018-06-04 18:08:29

有可能url中有同样的匹配模式,这样的话前者会覆盖后者,排在前面的优先。

回复
桀骜不驯镍铬合金
2018-05-22 21:21:05

发了个评论信息没显示, 再测试一下

回复
Arslan
2018-05-16 21:52:53

群主,你这个博客评论模块可以分享出来?我觉得很简洁很棒

回复
Arslan
2018-05-15 23:27:52

 Creating a ModelForm without either the 'fields' attribute or the 'exclude' attribute is prohibited; form CommentForm needs updating.求教这是怎么回事?

回复
追梦人物 Arslan
2018-05-16 12:25:27

提示已经告诉你了,指定  'fields' attribute,请参考教程的代码,确保拼写缩进等正确。

回复
Arslan 追梦人物
2018-05-16 20:56:46

找到了是拼写错误!谢谢

回复
guo73096
2018-05-15 16:32:11

禁止访问 (403)CSRF验证失败. 相应中断.您看到此消息是由于该站点在提交表单时需要一个CSRF cookie。此项是出于安全考虑,以确保您的浏览器没有被第三方劫持。如果您已经设置浏览器禁用cookies,请重新启用,至少针对这个站点,全部HTTPS请求,或者同源请求(same-origin)启用cookies。

回复
dlsxyt
2018-05-15 01:38:19

感谢博主

请问 ModuleNotFoundError: No module named 'blogproject.comments' 怎么办呢,谷歌了很久没找到靠谱的解决;同楼上的人说的 set project as source 再add source root to PYTHONPATH 也没解决

回复
dlsxyt dlsxyt
2018-05-15 01:43:37

也注册了,一切都是按步骤来的

回复
追梦人物 dlsxyt
2018-05-16 21:35:09

确保 comments 目录下有 __init__ 文件,这样才能让comments成为一个合法的package。

回复
gengjinpeng
2018-05-14 18:53:19

评论不能正常发表,总提示输入URL(实际URL已经输入)

回复
azunia
2018-05-11 09:49:23

求教,自己写了个评论回复功能,从页面表单里填写 ‘测试测试’ 四个字,可是后台提取到的存到数据库里的却是下面这样:

<tr><th><label for="id_data">Data:</label></th><td><textarea name="data" rows="10" cols="40" id="id_data"> 测试测试</textarea></td></tr>

期望只是   ‘测试测试’四个字的。

谁知道是什么原因吗?

回复
azunia azunia
2018-05-11 10:28:26

自己想了办法解决,不知道正规操作应该怎样

在后面加上了   .cleaned_data['键']

取到了键值。。。

正规操作应该怎么样呢?

回复
追梦人物 azunia
2018-05-13 17:25:50

就是这样的

回复
pyli.xm
2018-05-09 10:46:06

博主有没有讲你这个支持多层级的评论系统开源的打算啊,很喜欢你这个评论系统。😆

回复
追梦人物 pyli.xm
2018-05-10 16:01:21

在计划中了,但没多少时间写代码。

回复
pyli.xm 追梦人物
2018-05-11 18:30:24

我最近有些时间,可否帮上忙?

回复
曾小诚诚诚的
2018-05-04 17:44:20

AttributeError at /web/post/3/'Post' object has no attribute 'comment_set'

点击文章跳转时老是显示上面那个错误,谷歌找了好久没有比较好的答案,请问这要怎么解决?

回复
追梦人物 曾小诚诚诚的
2018-05-13 17:31:02

Post 改成指向你的文章的实例 post,而不是类 Post。

回复
海豹不是豹
2018-05-04 10:24:30

博主您好!我想问一下post.comment_set.all()的这种 xxx_set 这种方式或者说语法在django文档的哪个部分有体现

回复
追梦人物 海豹不是豹
2018-05-04 17:12:20

在关于介绍 model 的 ForeignKey 等表关联关系时有介绍。

回复
大力出奇迹6868
2018-04-22 14:53:56

评论测试

回复
wangmeng
2018-04-19 21:53:31

求教,我的点评页面输入框怎么不显示呢?也看到好几个人问同样的问题。。代码我都对了一遍了没啥问题啊。

forms.py:
```python

class CommentForm(forms.ModelForm):

    class Meta: 

    model = Comment 

    fields = ['name', 'email', 'url', 'text']

```

detail.html:

```python

<form action="{% url 'comments:post_comment' post.pk %}" method="post" class="comment-form"> {% csrf_token %} <div class="row"> <div class="col-md-4"> <label for="{{ form.name.id_for_label }}">名字:</label> {{ form.name }} {{ form.name.errors }} </div> <div class="col-md-4"> <label for="{{ form.email.id_for_label }}">邮箱:</label> {{ form.email }} {{ form.email.errors }} </div> <div class="col-md-4"> <label for="{{ form.url.id_for_label }}">URL:</label> {{ form.url }} {{ form.url.errors }} </div> <div class="col-md-12"> <label for="{{ form.text.id_for_label }}">评论:</label> {{ form.text }} {{ form.text.errors }} <button type="submit" class="comment-btn">发表</button> </div> </div> <!-- row --></form>

```

页面不显示输入框。

回复
wangmeng wangmeng
2018-04-20 10:43:42

解决了,原来是在blog/views.py中的detail方法没有设置comment的一些属性。

回复
dfjk59
2018-04-18 14:38:53

博主,你这个分层评论是怎么写的?

回复
pyli.xm dfjk59
2018-05-09 17:13:54

test

回复
Kengson pyli.xm
2019-05-10 11:47:33

test

回复
omucc
2018-04-16 22:57:09

# 将评论和被评论的文章关联起来。

comment.post = post

---这个地方不理解,不知道第一个post代表的是什么,又是具体怎么做的关联

回复
追梦人物 omucc
2018-04-18 13:56:15

comment 和 post 是一对多的关系,model 中用 foreignkey 关联。可以通过 comment.post 引用与这个 comment 关联的 post,也可以设置新的关联关系。

回复
a58982284 追梦人物
2018-04-27 09:59:12

还是不太明白其中的逻辑关系,请博主详细阐述一下,谢谢。

回复
追梦人物 a58982284
2018-04-27 17:07:06

你是否理解关系型数据库的表关联关系?

回复
花_易秋
2018-04-10 18:06:57

博主,你的阿里云推荐都好多人了,好聪明啊

回复
千松客
2018-04-09 16:35:33

 请问博主这个问题是出于什么那点错误,一直没找到解决方法   post_comment() got an unexpected keyword argument 'pk'   

回复
追梦人物 千松客
2018-04-10 13:53:59

只有异常信息难以定位问题,请附相关代码。

回复
千松客 追梦人物
2018-04-10 16:46:34

show.html

 <form id="comment-form" name="comment-form" action="{% url 'comments:post_comment' post.pk %}" method="POST">  {% csrf_token %}  <div class="comment"> <div class="row">  <div class="col-md-4"> <label for="{{ form.name.id_for_label }}">名称:</label> {{ form.name }} {{ form.name.errors }} </div>  <div class="col-md-4"> <label for="{{ form.email.id_for_label }}">邮箱:</label> {{ form.email }} {{ form.email.errors }} </div>  <div class="col-md-4"> <label for="{{ form.url.id_for_label }}">网址:</label> {{ form.url }} {{ form.url.errors }} </div>        </div> <label for="{{ form.text.id_for_label }}">评论:</label>  <div class="comment-box"> {{ form.text }} {{ form.text.errors }} <div class="comment-ctrl">  <div class="comment-prompt" style="display: none;"> <i class="fa fa-spin fa-circle-o-notch"></i> <span class="comment-prompt-text">评论正在提交中...请稍后</span> </div> <div class="comment-success" style="display: none;"> <i class="fa fa-check"></i> <span class="comment-prompt-text">评论提交成功...</span> </div> <button type="submit" name="comment-submit" id="comment-submit" tabindex="4">发表评论</button> </div> </div> </div></form><div id="postcomments"> <ol id="comment_list" class="commentlist"> {% for comment in comment_list %} <li class="comment-content"> <span class="comment-f">{{ comment.name }}</span> <div class="comment-main"> <p> <span class="time">{{ comment.created_time }}</span> <br> {{ comment.text }} </p> </div> </li> {% empty %} 暂无评论 {% endfor %} </ol></div> 

urls.py 

from django.urls import path  from . import views  app_name = 'comments'urlpatterns = [ path('comment/post/<int:pk>.html', views.post_comment,name='post_comment')] 

forms.py 

from django import forms from .models import Comment  class CommentForm(forms.ModelForm):  class Meta:  model = Comment  fields = ['name','email','url','text']  widgets = { 'text': forms.Textarea(attrs={'cols': '112.5'}) } 

提交评论跳转提示:post_comment() got an unexpected keyword argument 'pk'   

回复
千松客 追梦人物
2018-04-10 16:59:26

刚解决了,我把views.py里的post_pk 修改为pk就好了,

回复
追梦人物 千松客
2018-04-11 13:10:13

可能是你的视图函数没有pk参数,尝试设置 def view(request, pk=None):

回复
Foreve1Xf
2018-04-03 20:56:03

请问博主我的程序不会自己提示评论的输入格式错误是怎么回事

回复
追梦人物 Foreve1Xf
2018-04-04 12:00:42

什么意思?描述可否再具体一点呢?

回复
Foreve1Xf 追梦人物
2018-04-04 12:05:35

就是网址和邮箱不写正确的格式,虽然不会提交评论但是也不会提示格式错误

回复
追梦人物 Foreve1Xf
2018-04-04 12:07:40

你只有在提交评论,后台渲染后才能显示错误,然后要在模板中正确地渲染错误,通常是 field.errors。

回复
Foreve1Xf 追梦人物
2018-04-04 12:09:42

但是格式错了为什么提交不了呢?

回复
追梦人物 Foreve1Xf
2018-04-10 14:05:45

浏览器在客户端对用户的输入做检验的,正确才能提给后台。你可以关闭浏览器验证。

回复
ipandasbomb
2018-04-03 17:29:53

这里遇到了和跳转详情页面一节同样的问题,就是无法正确跳转,这里的解决办法是将myblog/urls.py 中的urlpatterns的comment路由放在第一位置,就可以了。

回复
lyg4795
2018-03-26 20:14:32

Error during template rendering In template /home/lyg/PycharmProjects/first_dj/templates/base.html, error at line 0Reverse for 'post_comment' with no arguments not found. 1 pattern(s) tried: ['comment/post/(?P<post_pk>[0-9]+)/$'] 怎么回事呀

回复
追梦人物 lyg4795
2018-03-28 10:38:38

是不是没有给 url 传参数?

回复
花_易秋 lyg4795
2018-04-03 16:54:36

在detail.html文件中{% url 'comments:post_comments' post.pk%} 这里是url拼接,报错是因为你的comments和post_comments参数错误,可能是你没有传对。前者是你的app_name的值,记得要在urls,文件中声明,后者是你的url别名,就是在comments.urls下的name值。不知道有没有帮到你,我刚刚解决了。

回复
qigaohua
2018-03-19 16:50:36

楼主,我问一下怎么在发表评论后,重定向回到页面的评论区域,而不是回到页面顶部啊

回复
追梦人物 qigaohua
2018-04-02 16:47:35

在评论的连接中加锚点,你可以看看我的评论系统中评论的链接和浏览器显示的链接锚点(#)

回复
derek-zhang123
2018-03-11 14:34:22

blog/views.py

要像我的这样才行,context=context的话是传不到模板detail中的


return render(request,'blog/detail.html',context)

回复
wishd
2018-03-08 16:28:35

有评论后再去后台删除文章会出错

回复
秋秋秋秋方
2018-02-27 12:00:38

post = models.ForeignKey('blog.Post',on_delete=models.CASCADE).外键老是忘记加on_delete,否则数据库总是保存不进去......

回复
各种迷惘的大明
2018-01-25 14:02:44

博主,你的评论功能是用的哪个框架呢?还是说是自己写的?

回复
追梦人物 各种迷惘的大明
2018-04-23 11:53:58

是自己写的,基于 django 开发的评论系统没有找到好用的框架。

回复
Zeng1998
2018-01-01 22:28:46

楼主我想问一下为什么我的评论那个输入框都显示不出来

<section class="comment-area" id="comment-area">
        <hr>
        <h3>发表评论</h3>
        <form action="{% url 'comments:post_comment' post.pk %}" method="post" class="comment-form">
            {% csrf_token %}
            <div class="row">
                <div class="col-md-4">
                    <label for="{{ form.name.id_for_label }}">名字:</label>
                    {{ form.name }}
                    {{ form.name.errors }}
                </div>
                <div class="col-md-4">
                    <label for="{{ form.email.id_for_label }}">邮箱:</label>
                    {{ form.email }}
                    {{ form.email.errors }}
                </div>
                <div class="col-md-4">
                    <label for="{{ form.url.id_for_label }}">URL:</label>
                    {{ form.url }}
                    {{ form.url.errors }}
                </div>
                <div class="col-md-12">
                    <label for="{{ form.text.id_for_label }}">评论:</label>
                    {{ form.text }}
                    {{ form.text.errors }}
                    <button type="submit" class="comment-btn">发表</button>
                </div>
            </div>    <!-- row -->
        </form>
        <div class="comment-list-panel">
            <h3>评论列表,共 <span>{{comment_list}}</span> 条评论</h3>
            <ul class="comment-list list-unstyled">
                {% for comment in comment_list %}
                    <li class="comment-item">
                        <span class="nickname">{{ comment.name }}</span>
                        <time class="submit-date"
                              datetime="{{ comment.created_time }}">{{ comment.created_time }}</time>
                        <div class="text">
                            {{ comment.text }}
                        </div>
                    </li>
                {% empty %}
                    暂无评论
                {% endfor %}
            </ul>
        </div>
    </section>
回复
Zeng1998 Zeng1998
2018-01-01 22:35:00

查了文档好像需要这样写

<input type="text" name="form.name" value="{{form.name}}"> 

这是因为django版本问题吗

回复
Zeng1998 Zeng1998
2018-01-01 23:14:06

已解决

回复
Fc_Hoang Zeng1998
2018-01-06 14:12:22

请问你怎么解决的, 我也是输入框显示不出来

回复
Fc_Hoang Zeng1998
2018-01-06 14:49:34

已解决

回复
Zeng1998 Fc_Hoang
2018-01-06 14:51:18

老哥是怎么解决的。。。我忘了。。

回复
Fc_Hoang Zeng1998
2018-01-06 14:57:24

原因未必一致,我看到你下面的评论是因为你的views.py写在blog下而不是comments下,我的原因是本来在forms.py中出了点问题,然后我以为是forms.ModelForm造成的,就改成forms.Form了,后来证明并不是这里有问题,就改回来,然后就显示出来了。

回复
Zeng1998 Fc_Hoang
2018-01-06 15:06:07

对对对我想起来了。。。。。多谢

回复
wangmeng Zeng1998
2018-04-19 21:42:54

求教,我的也是输入框不显示。。
代码我都对了一遍了没啥问题啊。

回复
吉超
2017-12-31 11:19:36

感谢博主的教程

回复
Xiao淩喺个死肥仔
2017-12-30 00:50:01

不知道有人说过这个没有,在detail页面里面,评论数量写死为4条了。但其实他应该应该等于comment_list的长度的。。所以应该改一下


<h3>评论列表,共 <span>{{ comment_list | length }}</span> 条评论</h3>

回复
吉超 Xiao淩喺个死肥仔
2017-12-31 16:49:10

是的

回复
xiaojunyang1 Xiao淩喺个死肥仔
2018-05-19 20:59:49

已知小问题修正 里面 有提到这个问题。用的{{ post.comment_set.count }}

回复
cnzaobao
2017-12-28 14:24:39

怎么实现,评论的回复及层级结构?

希望站长有空更新一下。

回复
EruDev
2017-12-18 15:32:45

为什么我点发表评论的时候,评论没有显示上去,也不报错

回复
EruDev EruDev
2017-12-18 15:43:11

解决了。。

回复
zhangbei59 EruDev
2017-12-21 16:25:23

我也一样的问题,怎么解决的,点击发表就刷新下了页面,但是没有提交成功

回复
小Q营姐 EruDev
2017-12-23 21:49:23

层主知道为什么了吗?求解。

回复
小Q营姐 EruDev
2017-12-23 21:52:26

层主知道为啥了吗?求解。

回复
啃包菜的猫8023 小Q营姐
2017-12-31 01:24:24

把你的comments/views.py 里 post_comment好好的和博主的对一遍就知道了

回复
kangarooJie EruDev
2018-01-16 13:36:20

你好, 你是怎么解决的, 我也遇到这个问题

回复
Jiheng Hu EruDev
2018-04-01 20:03:26

其实大家在复制修改blog/view.py 时没有修改` return render(request, 'blog/detail.html', context={'post': post})` ===>  `return render(request, 'blog/detail.html', context=context)`

回复
ipandasbomb Jiheng Hu
2018-04-03 17:22:39

修改了,都正常,但是无法提交评论,为何?

回复
张小二_tiny Jiheng Hu
2018-05-11 11:17:17

这个靠谱。。。

回复
suxianglun EruDev
2018-08-21 14:25:28

怎么解决的啊

回复
Simoral
2017-12-09 16:00:33

# 出现问题:NoReverseMatch at / 'blog' is not a registered namespace

## 百度获取到的解决方案:

- 在url.py内添加

```python

app_name = 'comments'

```

未解决,重新按照本片教程操作一遍后,发现自己将教程内的应用“blog”更名为“blogapp”,考虑可能是这个问题,于是去base.html文件内搜索,发现[分类]有一行代码打错了:

```python

<a href="{% url 'blog:category' category.pk %}">{{ category.name }} <span class="post-count">(13)</span></a>

```

这里应该写成我自己的应用名:blogapp而不是blog

回复
叶小凯凯
2017-12-03 02:39:42

博主您好,能更新一下评论回复功能的讲解吗?感觉不是很好理解。

回复
NiceAir
2017-11-29 08:11:19

博主,我在学习你的博客教程。做到这里的时候出现无法解决的问题了: 给文章评论后点击提交,然后界面就会刷新,之后评论界面还是原来的样子,我查了数据库里没有评论的数据

回复
啃包菜的猫8023 NiceAir
2017-12-31 01:24:55

把你的comments/views.py 里 post_comment好好的和博主的对一遍就知道了

回复
谢亚波
2017-11-25 16:20:36

Image

回复
huyuhuyu
2017-11-17 23:28:17

大佬,为什么我的博文那一页能显示评论数,但是没有显示评论,进到发表评论里,可以看到其他评论

回复
Zz丶LoveYou
2017-11-16 10:35:00

该评论涉及无意义的内容而被删除

回复
Zz丶LoveYou
2017-11-15 16:46:00

该评论涉及无意义的内容而被删除

回复
Zz丶LoveYou
2017-11-09 09:41:47

请问一下  如果我想给表单加点样式该怎么弄

回复
追梦人物 Zz丶LoveYou
2017-11-09 11:49:39

使用 css,或者使用第三方库,django-crispy-form

回复
williamzz2015
2017-11-05 00:23:48

楼主好

url(r'',include('blog.urls')), 

url(r'',include('comments.urls')),

我在代码中 include这两个urls评论功能一直存不上,但是我把他俩上下行调换一下就好了,这个怎么回事

回复
长叶manman williamzz2015
2017-11-22 19:30:23

我也是这样,这是为什么啊?

回复
zacklam 长叶manman
2018-04-20 17:58:34

我也想知道。我也是这样的。太变态了。我的python版本是3.6

回复
williamzz2015
2017-11-04 23:34:59

from comments.forms import CommentForm

楼主好 ,这个在详情视图那个导入的时候就是报错,怎么搞都不对,求破

   from .import views  File "/Users/zhangzhe/Documents/my/pyblog/pyblog/comments/views.py", line 2, in <module>    from ..blog.models import PostValueError: attempted relative import beyond top-level package

回复
追梦人物 williamzz2015
2017-11-08 11:17:27

attempted relative import beyond top-level package:你指定的导入路径已经超过包的最外层边界。越界了,确保从个正确的路径导入,一个点代表上一级目录。

回复
kingleoric2010
2017-10-31 15:47:58

感觉comment的URL的字段没有什么用

回复
song of code
2017-10-19 00:41:19

博主,在blog下view视图中导入comments模块的form类时报错,from blogproject.comments import forms,和from comments import forms都不行。

错误信息:  

File "F:\PythonProject\Myblog\blogproject\blog\views.py", line 8, in <module>    from blogproject.comments import formsModuleNotFoundError: No module named 'blogproject.comments'

能解释一下是什么原因吗

回复
lm聿喵 song of code
2017-11-03 00:09:27

我想问下 您解决了这个问题吗

回复
逗趣小叮当 song of code
2018-03-12 11:30:31

您好,您的问题解决了嘛

回复
花_易秋 song of code
2018-04-03 17:01:28

from comments.forms import CommentForm 你这样试试。导入就是去找路径,基础不扎实的话要去看看import方法

回复
安东6gold
2017-10-17 13:13:39

http://127.0.0.1:8000/comment/post/6/  点击发表之后到了这个链接,并且评论内容无法保存,求助求助

回复
偕兮 安东6gold
2017-10-20 15:35:25

是不是你的前端里面{{ form.text.id_for_label }}没写

回复
安东6gold 偕兮
2017-10-20 21:45:41

谢谢你代码我都一样的。。我也不知道咋回事莫名其妙的好了、、

回复
安东6gold
2017-10-17 13:04:46

测试评论

回复
安东6gold
2017-10-17 04:13:23

提交表单不能成功保存在数据库,代码没有报错。

直接在数据库填写评论倒是可以显示。

求助大神啊啊啊啊啊啊啊啊啊

回复
SeaTimeMoon
2017-10-14 23:06:44

Error during template rendering In template D:\PythonWork\Django_Blog\templates\blog\detail.html, error at line 117 no such column: comments_comment.text

反复检查还是如此,说是detail.html有错。 

{% for comment in comment_list %}

回复
偕兮 SeaTimeMoon
2017-10-20 14:52:33

 我也是这个问题。不知道怎么解决

回复
偕兮 偕兮
2017-10-20 15:04:32

以解决,重新迁移了数据库就成功了。

回复
白色的小方块 SeaTimeMoon
2018-04-19 23:53:54

你这是途中改过models.py里的东西了,重新迁移数据库应该就可以解决

回复
ByPupil
2017-10-02 13:42:33

博主你好!comments/views.py中的if的else部分可以直接用redirect(post)比较好,可以避免render()函数处理模板的时候markdown部分没有进行处理,重复写了代码。

回复
RemeLL
2017-09-25 17:05:05

NoReverseMatch at /post/2/Reverse for 'comment_post' with arguments '('',)' and keyword arguments '{}' not found. 1 pattern(s) tried: ['comment/post/(?P<post_pk>[0-9]+)/$']

这个问题找了半天找不到哪里有问题,是post_pk没传过去吗?

回复
大叔你好嫩 RemeLL
2017-10-21 17:06:51

应该是post.pk

回复
Fire___Within
2017-09-18 11:25:13

博主请问我再导入from ..comment.forms import CommentForm 出现

from ..comment.forms import CommentForm

怎么解决

回复
Fire___Within Fire___Within
2017-09-18 11:39:03

是出现了Valueerror:Attempted relative import beyond top-level package错误

回复
Fire___Within Fire___Within
2017-09-18 14:46:50

已解决

回复
Tom Fire___Within
2017-09-24 10:25:01

我也是这个错,怎么解决的?~求指导~

回复
lm聿喵 Fire___Within
2017-11-03 00:12:03

请问是怎么解决的呢

回复
抱着一米八的大长腿 lm聿喵
2017-11-22 18:32:46

请问您解决了吗?求告知

回复
抱着一米八的大长腿 Fire___Within
2017-11-22 18:35:09

请问如何解决的啊?

回复
Mao Yuanbo Fire___Within
2018-08-21 17:43:28

到底是怎么解决的????卡好久了

回复
Faraday179
2017-09-15 09:39:22

博主好, 在评论面提交后, 会报错: TypeError: argument of type 'Post' is not iterable,

但是重新刷新评论页面后,  却发现评论内容已经提交成功了, 这个问题应该怎么查?  谢谢.

回复
Skyge Faraday179
2017-09-15 18:06:00

我也被这个问题难住了,还没有找到很好的解决办法。。。。。

回复
追梦人物 Faraday179
2017-09-15 21:30:21

看样子你似乎对 Post 类进行了迭代,看看哪一部分的代码与这个相关,然后贴出来看看。

回复
Faraday179 追梦人物
2017-09-15 23:48:24

谢谢博主的提醒, 刚才试着修改了redirect部分, 好象正常了.

刚开始跟着博主的文章学django, 虽然现在正常了, 但是还没完全明白为什么原来的写法retrun redirect(post) 报错?

comments/view.py:

def post_comment(request, post_pk):  

    post = get_object_or_404(Post, pk=post_pk)

    if request.method == 'POST': 

        form = CommentForm(request.POST)

        if form.is_valid():  

            comment = form.save(commit=False) 

            comment.post = post 

            comment.save()

            # 替换redirect中的post为下面的红色部分就可以正常提交了

           # retrun redirect(post)

            return redirect('blog:detail', pk=post_pk)

 .......

说明 : url配置如下

blogproject/urls.py:

 urlpatterns = [ url(r'^admin/', admin.site.urls),    

                        url(r'', include('blog.urls', namespace='blog')),    

                        ...... ]

blog/urls.py

urlpatterns = [ url(r'^$', views.index, name='index'), 

                       url(r'^post/(?P<pk>[0-9]+)/$', views.detail, name='detail'),

                      .....]

回复
Skyge 追梦人物
2017-09-16 21:34:50

我的原因找到了,因为我在 blog/models.py 里忘记定义  get_absolute_url()  了,

这个 get_absolute_url() 方法我还是第一次使用,看来要学习一下了。谢谢博主的文章!

回复
edsszw
2017-09-12 21:41:58

看了一眼,博主你这个评论貌似会存在XSS的危险啊。Django会帮你过滤掉那些特殊符号吗?

<img src="#">

回复
追梦人物 edsszw
2017-09-13 13:46:39

目前我使用的富文本编辑器对 xss 攻击做了防护,使用的js,python端的防护可以使用 bleach 包。django 本身默认开启了 xss 防护,转义全部 html 字符,但这样用户就不能用富文本了。

回复
edsszw 追梦人物
2017-09-13 20:51:25

嗯,最好还是小心一点。因为评论这部分一旦发生xss,就是存储型的xss。存储型的xss就对比反射型的xss就严重多了。可以做很多事情。个人见解

回复
lamber edsszw
2018-03-15 16:16:08

自己写一个中间件过滤一下吧。。。

回复
又一块大番薯
2017-09-11 10:42:19

点击「发表」后,表单数据并没有存入数据库,重定向后表单后面还是没有评论,也不报错。

cmd 出现的信息:

```

[11/Sep/2017 10:37:27] "POST /comment/post/1/ HTTP/1.1" 302 0 

[11/Sep/2017 10:37:29] "GET /post/1/ HTTP/1.1" 200 20094

```

回复
追梦人物 又一块大番薯
2017-09-11 12:36:07

能看看你的模板显示评论的代码以及评论视图和详情视图的代码么?用富文本编辑器贴代码,不支持markdown

回复
又一块大番薯 追梦人物
2017-09-11 13:19:56

显示评论:

            <ul class="comment-list list-unstyled">
                {% for comment in comment_list %}
                <li class="comment-item">
                    <span class="nickname">{{ comment.name }}</span>
                    <time class="submit-date">{{ comment.created_time }}</time>
                    <div class="text">
                        {{ comment.text }}
                    </div>
                </li>
                {% empty %}
                暂无评论
                {% endfor %}
            </ul>

评论视图( app 应用相当教程中的 blog 应用 ):

def post_comment(request, post_pk):
    post = get_object_or_404(Post, pk=post_pk) # 获取当前文章
    if request.method == 'Post':
        form = CommentForm(request.POST)
        if form.is_valid():
            # save 后,由 CommentForm 实例生成 Comment 实例
            comment = form.save(commit=False) 
            comment.post = post # 该实例 post 字段赋值
            comment.save() # 保存到数据库
            return redirect(post)
        else:   # 表单数据无效,重新渲染页面
            comment_list = post.comment_set.all()
            context = {
                'post': post,
                'form': form,
                'comment_list': comment_list,
            }
            return render(request, 'app/detail.html', context=context)
    else:      # 不是 Post 请求
        return redirect(post)

详情视图:

def detail(requests, pk):
    post = get_object_or_404(Post, pk=pk)
    post.body = markdown.markdown(post.body, extensions=['markdown.extensions.extra', 
        'markdown.extensions.codehilite', 'markdown.extensions.toc',])

    form = CommentForm()
    comment_list = post.comment_set.all()
    context = {
        'post': post,
        'form': form,
        'comment_list': comment_list,
    }
    return render(requests, 'app/detail.html', context=context)
回复
又一块大番薯 追梦人物
2017-09-11 15:08:07

啊啊啊!!!我知道了!:

if request.method == 'POST' # 不是 Post
回复
追梦人物 又一块大番薯
2017-09-12 09:42:40

恩恩,解决了就好!

回复
xiaomintongxue
2017-09-05 21:22:39

from blog.models import Post怎么导入不了?

另外运行出错,提示Valueerror:Attempted relative import beyond top-level package

回复
追梦人物 xiaomintongxue
2017-09-05 22:12:44

似乎是你的项目结构问题,导入路径需要和项目结构一致,例如你 from blog.models import Post 就要保证 Post 在 blog 文件夹的 models.py 模块里。

回复
爱coding xiaomintongxue
2017-12-12 17:05:07

同学你的问题解决了吗

回复
林阁姑娘
2017-08-31 15:13:02

代码检查了很多遍,CommentForm也一模一样,为什么还会报错提示未定义呢?

NameError at /post/3/
name 'CommentForm' is not defined
Request Method: GET
Request URL: http://127.0.0.1:8000/post/3/
Django Version: 1.10.6
Exception Type: NameError
Exception Value:
name 'CommentForm' is not defined
Exception Location: C:\Users\Administrator\Workspace\blogproject\blog\views.py in detail, line 46
Python Executable: D:\python-env\Envs\blogproject_env\Scripts\python.exe
Python Version: 3.5.2
Python Path:
['C:\Users\Administrator\Workspace\blogproject',
'D:\python-env\Envs\blogproject_env\Scripts\python35.zip',
'D:\python-env\Envs\blogproject_env\DLLs',
'D:\python-env\Envs\blogproject_env\lib',
'D:\python-env\Envs\blogproject_env\Scripts',
'd:\python\Lib',
'd:\python\DLLs',
'D:\python-env\Envs\blogproject_env',
'D:\python-env\Envs\blogproject_env\lib\site-packages']

回复
追梦人物 林阁姑娘
2017-08-31 19:48:48

确定在顶部从 forms.py 导入了该类么?

回复
JoJo小昌
2017-08-30 03:38:24

完全按照博主的代码写的,但是 {{form.xxxx}}并没有变成input,进入文章后,评论区不显示表格,必须点击“提交”之后才能显示表格。输入内容并提交之后,必须再次点击“提交”才能在下方显示提交的内容

回复
追梦人物 JoJo小昌
2017-08-30 12:42:29

是否有修改 detail 视图函数的代码?

回复
JoJo小昌 追梦人物
2017-08-30 15:21:47

detail代码跟博主一样的.


{{ form.name }}
{{ form.name.errors }}
这段代码在点击submit之前,显示为:

点击submit后,才能正常显示 :

回复
JoJo小昌 追梦人物
2017-08-30 16:08:13

我发现问题了,刚进入文章是 url为 http://127.0.0.1:8000/post/1/,没有input。但是点击submit后,url变为http://127.0.0.1:8000/comment/post/1/,出现了input,可以写评论。写完评论,点击提交,url又变为 http://127.0.0.1:8000/post/1/,不显示评论(但是正常显示评论数量)

回复
追梦人物 JoJo小昌
2017-08-30 16:14:53

让我看一下你的 detail 视图函数。

回复
JoJo小昌 追梦人物
2017-08-30 16:17:57
{% csrf_token %}
{{ form.name }} {{ form.name.errors }}
{{ form.email }} {{ form.email.errors }}
{{ form.url }} {{ form.url.errors }}
{{ form.text }} {{ form.text.errors }}
回复
JoJo小昌 追梦人物
2017-08-30 16:19:46

def detail(request, pk):
post = get_object_or_404(Post, pk=pk)
post.body = markdown.markdown(post.body,
extensions=[
'markdown.extensions.extra',
'markdown.extensions.codehilite',
'markdown.extensions.toc',
])
# 记得在顶部导入 CommentForm
form = CommentForm()
# 获取这篇 post 下的全部评论
comment_list = post.comment_set.all()

# 将文章、表单、以及文章下的评论列表作为模板变量传给 detail.h    模板,以便渲染相应数据。
context = {'post': post,
            'form': form,
            'comment_list': comment_list
            }
return render(request, 'blog/detail.html', context={'post': post})
回复
追梦人物 JoJo小昌
2017-08-30 16:21:41

你需要把 form 传给模板,最后一行改为:return render(request, 'blog/detail.html', context=context )

回复
JoJo小昌 追梦人物
2017-08-30 16:23:27

谢谢博主,我找到问题了!!!!!
return render(request, 'blog/detail.html', context=context) 这个才是正确的,我之前写错

回复
Zeng1998 JoJo小昌
2018-01-01 23:01:57

为什么我的有写

return render(request, 'blog/detail.html', context=context)

啊 还是没有出现评论的框

回复
Zeng1998 JoJo小昌
2018-01-01 23:13:47

好了好了 原来这个view是blog下的view 一直改comment下的

回复
花重-城
2017-08-29 20:36:49

有办法让不点浏览者不点评论的时候显示其他的评论吗

回复
追梦人物 花重-城
2017-08-29 21:00:36

当访问文章详情页时评论列表就是显示的呀。

回复
皮皮欧呢
2017-08-27 14:34:54

解决了,谢谢博主!

回复
皮皮欧呢
2017-08-27 14:23:08

我这是制定了model吧?
from .models import Comment
from django.forms import ModelForm

class CommentForm(ModelForm):
class Meta:
modle = Comment
fields = ['name','email','url','text']

回复
追梦人物 皮皮欧呢
2017-08-27 22:21:36

modle -> model

回复
皮皮欧呢
2017-08-27 09:41:18

ModelForm has no model class specified.博主你好,我在做评论功能时总是报错,我把form=CommentForm() 和context中的"form":form注释掉之后就不报错,但是应该不是理想中的界面

回复
追梦人物 皮皮欧呢
2017-08-27 12:12:10

ModelForm has no model class specified,报错已经告诉你了,你可能没有指定 ModelForm 对应的 model。

回复
githuber
2017-08-26 21:24:26

问一下这是什么问题:

django.template.exceptions.TemplateSyntaxError: Invalid block tag on line 27: 'form.name.id_for_lable', expected 'endblock'. Did you forget to register or load this tag?

回复
githuber githuber
2017-08-26 21:26:46

解决了😂

回复
丨风灬起
2017-08-25 15:49:05

博主你好,教程里的评论是不支持markdown的吗,我试了好久,好像就是没法用markdown渲染,博主你有什么实现方案吗

回复
丨风灬起 丨风灬起
2017-08-25 16:04:05

啊,不用了博主,我做到了,谢谢博主的教程,太棒了

回复
追梦人物 丨风灬起
2017-08-25 16:08:14

嗯嗯,教程中没有做,不过相信自己做也是很简单的吧。不过对于评论这种由用户发布的内容,支持markdown时要注意防止 xss (跨站脚本)攻击。

回复
吉超 追梦人物
2017-12-31 17:21:33

这个我也实现了,谢谢博主的教程

回复
SamK6517433923 吉超
2018-09-06 16:39:05
请问,评论怎么实现markdown,在blog/views.py ,添加以下代码后,没有成功实现
comment_list.text = markdown.markdown(comment_list.text, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ])
回复
SamK6517433923 吉超
2018-09-07 09:07:52

你好,评论如何支持markdown了,我试了好久,好像就是没法用markdown渲染,你是如何解决了?

回复
要你罩啊时哲啊
2017-08-21 18:47:13

评论是即时显示的吗

回复
要你罩啊时哲啊 要你罩啊时哲啊
2017-08-21 18:47:33

我在试试

回复
要你罩啊时哲啊 要你罩啊时哲啊
2017-08-21 18:59:25

测试

回复
逐殇小彬
2017-08-18 16:01:50

NoReverseMatch at /post/1/
Reverse for 'post_comment' not found. 'post_comment' is not a valid view function or pattern name.


Error during template rendering

In template D:\blogproject\templates\base.html, error at line 0

D:\blogproject\blog\views.py in detail

  1. return render(request, 'blog/detail.html', context=context)
    -----这个是什么报错 求救。。
回复
追梦人物 逐殇小彬
2017-08-18 17:41:06

Reverse for 'post_comment' not found. 'post_comment' is not a valid view function or pattern name.

你可能没有正确地设置好 post_comment 视图函数的 name 参数名。

回复
逐殇小彬 追梦人物
2017-08-21 17:11:44

是的 拼写有点问题 谢谢

回复
韭菜尖儿
2017-08-18 14:08:30

测试下

回复
woming26hua
2017-08-12 15:22:27

测试下

回复
leonfrank
2017-08-12 10:09:11

已经发布的评论要在点击“发表”按钮后才能够显示,可不可以打开文章详情页就显示?
然后在评论区的“名字”,“邮箱”输入框下面都有“这个字段是必填项”请问这个提示可以删除吗

回复
追梦人物 leonfrank
2017-08-13 16:15:28

你的代码可能和教程中示例项目的不一致,示例项目的效果是你期望的效果。至于“名字”,“邮箱”改成非必填,可以进一步定制表单,添加 required=False 这个参数,不过需要你自行探索 django 的文档和表单的 API。

回复
leonfrank 追梦人物
2017-08-13 23:11:41

好的 谢谢博主!请问博主用的是什么评论系统,可以发布吗

回复
追梦人物 leonfrank
2017-08-14 10:17:35

自己写的,没有开源出来(还达不到开源给他人使用的标准)。如果不想自己写的话可以使用一些第三方的评论库,例如畅言/网易云跟帖等应用。github 上也有一些很不错的开源应用如 gitalk。

回复
leonfrank 追梦人物
2017-08-15 08:52:08

谢谢你的解答,太好了!

回复
丨风灬起 leonfrank
2017-08-25 14:58:30

你好,你的问题解决了吗,我也出现同样的问题,如果你还记得的话告诉我一下

回复
丨风灬起 丨风灬起
2017-08-25 15:12:45

OK,解决了,是我自己不够仔细

回复
dackzome
2017-08-08 14:11:59

补充下,这个报错发生于点击【发表】之后

回复
dackzome
2017-08-08 14:10:19

Page not found (404)
Request Method: GET
Request URL: http://127.0.0.1:8000/comment/post/1/%3Cbound%20method%20Post.get_absolute_url%20of%20%3CPost:%20jinmy%E8%A6%81%E5%97%A8%E8%B5%B7%EF%BC%9F%3E%3E
Using the URLconf defined in blogproject.urls, Django tried these URL patterns, in this order:
^admin/
^$ [name='index']
^post/(?P[0-9]+)/$ [name='detail']
^archives/(?P[0-9]{4})/(?P[0-9]{1,2})/$ [name='archives']
^category/(?P[0-9]+)/$ [name='category']
^comment/post/(?P[0-9]+)/$ [name='post_comment']
The current path, comment/post/1/>, didn't match any of these.
You're seeing this error because you have DEBUG = True in your Django settings file. Change that to False, and Django will display a standard 404 page.

【大佬,爆这个错这么办?我返回文章页面,刷新,发现实际上评论已成功。】

回复
追梦人物 dackzome
2017-08-08 20:54:33

你 url 后面跟了一串东西:%3Cbound%20method%20Post.get_absolute_url%20of%20%3CPo,看看是不是你的模板中写上去的或者是视图函数有问题?

回复
dackzome 追梦人物
2017-08-14 17:27:57

大佬,我用的是django1.11,反正我对照了代码,都跟你的一模一样,还是报错。后面我去看了http://www.jianshu.com/p/53bf20eb479c 【Django By Example】的例子,把代码改成如下,居然不报错了~~,能分析下原因么?n难道真是版本原因?
def post_comment(request, post_id):
post = get_object_or_404(Post, id=post_id)
comment_list = post.comment_set.all()
if request.method == 'POST':
form = CommentForm(request.POST)
if form.is_valid():
comment = form.save(commit=False)
comment.post = post
comment.save()
else:
form = CommentForm()
context = {'post': post,
'form': form,
'comment_list': comment_list}
return render(request, 'blog/detail.html', context=context)

回复
追梦人物 dackzome
2017-08-14 17:41:41

你改了什么地方,开始报什么错?

回复
亲爱的-阿涛
2017-08-07 11:40:19

django.db.migrations.exceptions.BadMigrationsError:Migrations blog_tags in app has no Migrations class请问这个问题怎么解决,在迁移数据库时报错,我用的mysql数据库

回复
追梦人物 亲爱的-阿涛
2017-08-07 19:42:56

似乎 django 把 blog_tags 当成了迁移文件。确保 blog_tags 在 templatetags 文件夹下,不在 migrations/ 下。如果还有问题,给我看看你的文件结构。

回复
亲爱的-阿涛 追梦人物
2017-08-17 12:40:44

感谢博主,已解决

回复
木二Lin
2017-08-05 11:09:37

我想问问博主现在创建了连个应用,但是admin界面怎么用呢,不同应用的好像是分开的

回复
追梦人物 木二Lin
2017-08-05 18:34:37

是的,不同应用是分开的。

回复
唐小扣
2017-08-04 15:06:05

https://github.com/cody1991/learn/tree/gh-pages/django/blog

好奇怪 我发现我写的这个 redirect 没用,输入的地址是 comment/post/ 也不会重定向哎。。

https://github.com/cody1991/learn/blob/gh-pages/django/blog/comments/views.py#L9-L47

看代码也没看出什么错

回复
追梦人物 唐小扣
2017-08-04 21:01:21

是不是在模板中没有传 post.pk 给评论视图函数?

回复
唐小扣
2017-08-04 14:40:57
回复
yangxiang12
2017-07-31 18:35:07
回复
xueshichaoya
2017-07-29 23:12:05

博主的评论能发出去后能自动换行吗?我看你这截图是这样,但是实际上好像不能啊

回复
追梦人物 xueshichaoya
2017-08-04 15:13:14

项目中不能,如果要支持自动换行,可以使用 linebreakbr 模板标签,推荐看看 django 内置的模板标签。

回复
xueshichaoya 追梦人物
2017-08-06 19:33:41

好的,谢谢!

回复
xueshichaoya
2017-07-29 20:32:20

ssa

回复
liuxinglan13
2017-07-29 17:10:01

你好啊 测试!!

回复
恠往逺方
2017-07-28 01:14:27

楼主,请问个问题,在comments/views.py的模块中,其中comment=form.save(commit=False)这一句,comment这个变量并没有在哪个地方声明或者定义是一个Comment类的实例,form这个只是CommentForm的实例,怎么comment就成了Comment模型的实例了呢?

回复
追梦人物 恠往逺方
2017-08-04 20:31:35

form.save(commit=False) 方法返回一个模型 Comment 的实例。由于 Python 是动态语言,因此无需定义变量 comment 即可直接使用。

回复
LincolnBurrows2017
2017-07-23 20:35:51

File "C:\Users\bo.ma.fs\PycharmProjects\PycharmProjectsMabo\PycharmProjects\blogproject\blog\urls.py", line 2, in
from . import views
File "C:\Users\bo.ma.fs\PycharmProjects\PycharmProjectsMabo\PycharmProjects\blogproject\blog\views.py", line 4, in
from ..comments.forms import CommentForm
ValueError: attempted relative import beyond top-level package
博主你好,问一下这个错误是怎么回事?
我在导入的时候是这样导入的
from ..comments.forms import CommentForm
因为直接from comments.forms import CommentForm会报错,但是这样就报另外一种错误

回复
追梦人物 LincolnBurrows2017
2017-07-24 21:00:59

为什么会报错呢?难道引用的路径不对么?

回复
奇楠之后 LincolnBurrows2017
2018-02-06 21:58:52

我也出现了,只要右键点击项目名称,将选项make directory as 选为 sources root,查了好久,希望能对后面遇到的人有所帮助。

回复
Xu Lichen
2017-07-23 19:17:56

找了一下评论没有发现跟我一样问题的。
我在评论区块里面遇到CSS没有加载出来的现象,包括发表评论跟评论列表。
然后我就去查看CSS文件,本地显示出来的跟Chrome上的custom.css发现不同,缺少了12,13部分关于评论的css内容,总行数少了100多行。而且第一部分google font 多出来
@import url(http://fonts.useso.com/css?family=Lato:300,400);
@import url(http://fonts.useso.com/css?family=Ubuntu:300,400);

跟我本地的CSS文件是不同的。
然后我又在github上直接拷贝了一份comment分支的教程,配好后运行也出现CSS异常。不知道为什么,还有遇到这种情况的人吗

回复
Xu Lichen Xu Lichen
2017-07-23 19:39:32

有一点说错了,custom.css第13部分是分页的css。在Chrome的sources上同评论内容一样也是没有的,博客上仅是缺失这2块的css,其他的都显示完美。
还有,本地下载模板,不通过django直接运行评论区和分页是可以显示的

回复
Xu Lichen Xu Lichen
2017-07-23 20:14:04

= =因为我的模板是从别的网上下载下来的,版本比较老。换了新版的css但是最初的custom.css被Chrome缓存了,清一下缓存就显示正常了

回复
xuna
2017-07-22 10:50:41

请问一下这个问题怎么解决呀???
Request Method: POST
Request URL: http://localhost:8000/post/3/%7B%25%20url%20'comments:post_comment'%20post.pk%7D

Using the URLconf defined in blogproject.urls, Django tried these URL patterns, in this order:

^admin/
^$ [name='index']
^post/(?P<pk>[0-9]+)/$ [name='detail']
^comment/post/(?P<post_pk>[0-9]+)/$ [name='post_comment']

The current path, post/3/{% url 'comments:post_comment' post.pk}, didn't match any of these.

回复
追梦人物 xuna
2017-07-24 21:08:42

仔细对比一下各个 url 是否和项目示例中的匹配。

回复
qw243211462
2017-07-21 10:59:16

请问一下遇到这个问题怎么解决。
django.db.utils.OperationalError: no such table: comments_comment

回复
追梦人物 qw243211462
2017-07-24 21:11:51

可能没有创建数据表,你对比一下教程看是不是漏了哪一步?

回复
DawnOct
2017-07-20 13:36:26

有个问题纠结了很久. 我在android端上传图片, 我的需求是,图片上传到项目目录下, 保存在数据库的是图片路径. 可是我实现不了....

代码:
Post 的model 其中一个字段是
post_imag = models.FileField(upload_to='imgs/', blank=True)

files = data['start_in0'] #获得的是二进制数据
post = Post(village=village, created_time=timezone.now())
post.post_imag = files
post.save()

回复
追梦人物 DawnOct
2017-07-20 17:47:19

你的这段代码运行后是什么结果?

回复
DawnOct 追梦人物
2017-07-31 09:46:25

我已经解决了,是我android端写的有问题. 还是感谢,是博主让我认识了django... 因为你写的非常详细,让人入门很顺滑....

回复
大数据菜
2017-07-06 22:05:35

这个例子没跑通,液面上form里的input都没有显示出输入框。
html代码是这样的‘ ’,for后面的id_name没有输出出来,在blog/views.py里打印 form.name.id_for_label,报错说form没有name这个属性。
我用的是django1.11

回复
追梦人物 大数据菜
2017-07-07 11:44:08

让我看看你的 form 代码。

回复
大数据菜 追梦人物
2017-07-09 00:12:49
{% csrf_token %}
{{ form.name }} {{ form.name.errors }}
{{ form.email }} {{ form.email.errors }}
{{ form.url }} {{ form.url.errors }}
{{ form.text }} {{ form.text.errors }}
回复
追梦人物 大数据菜
2017-07-10 11:33:18

怀疑是没有设置表单属性,下面的代码:

class CommentForm(forms.ModelForm):
class Meta:
model = Comment
fields = ['name', 'email', 'url', 'text']

fields 中要指定你设置的表单属性。

回复
forgood一下sj
2017-07-05 22:54:28

求助!
我现在在页面发送评论后,cmd 显示POST那一条是200 成功的,但是数据库就是没有添加数据,导致没有评论展示。我是python2.7.13 django1.11.2

回复
追梦人物 forgood一下sj
2017-07-06 16:01:27

是不是没有调用表单的 save 方法?或者没有把提交的数据传给表单?

回复
forgood一下sj 追梦人物
2017-07-08 22:56:37

表单调用了save()方法,数据也是传给表单了,POST方法

回复
forgood一下sj 追梦人物
2017-07-08 23:06:25

我把您的代码全部复制了一遍还是不行

回复
forgood一下sj 追梦人物
2017-07-09 21:20:12

然后我下了源代码,一个个文件试,替换了 blog_tags.py 就好了,好像是编码的问题,总之感觉是个案,好奇怪。。

回复
赵小爷zp
2017-07-05 21:02:39
{% csrf_token %}
{{ form.name }} {{ form.name.errors }}
{{ form.email }} {{ form.email.errors }}
{{ form.url }} {{ form.url.errors }}
{{ form.text }} {{ form.text.errors }}

这部分前端代码并没有输入编辑框的元素,为何展现结果里会有呢

回复
追梦人物 赵小爷zp
2017-07-06 16:02:26

例如 {{ form.text }} 实际就是 元素,这是 django 内部自动生成的。

回复
Foreve1Xf 追梦人物
2018-04-25 16:11:31

请问如果不用这个 {{ form.text }} 用自己写的input样式的话表单模型该怎么和html里的表单匹配呢?

回复
追梦人物 Foreve1Xf
2018-04-26 12:12:09

只要html的表单的name属性和form的field属性对应就可以了。

回复
陌上花开迟迟
2017-07-01 09:43:20

怎么实现微博,qq登录评论功能?

回复
追梦人物 陌上花开迟迟
2017-07-01 11:11:26

django-allauth

回复
陌上花开迟迟 追梦人物
2017-07-02 12:07:18

左边栏的内容显示在右边栏下面,比如显示在推荐阅读下面是怎么回事?

回复
陌上花开迟迟 陌上花开迟迟
2017-07-02 14:07:57

这个问题已解决,不麻烦博主了。那个阅读数怎么设置?

回复
陌上花开迟迟 陌上花开迟迟
2017-07-02 14:09:31

看见16了,谢谢博主!

回复
吉超 陌上花开迟迟
2017-12-31 18:16:48

什么看到16了呀

回复
刘智彬会灰
2017-06-28 21:43:42

ModuleNotFoundError: No module named 'blogcomments'

我也不知道哪里出错了,我好像并没有用blogcomments这东西

回复
追梦人物 刘智彬会灰
2017-06-29 14:48:48

你可能在代码中导入了什么,删掉这些导入的包就行。

回复
静静地林子中有雨 刘智彬会灰
2017-07-25 14:50:29

INSTALLED_APPS = [
...
'blog',
'comments']
你blog后面没加逗号

回复
仗剑踏歌行_Hung
2017-06-25 10:38:48

不是很理解 为什么在下面这段代码里的for中, comment_list 可以直接用.....

    {% for comment in comment_list %}
  • {{ comment.name }}
    {{ comment.text }}
  • {% empty %} 暂无评论 {% endfor %}
回复
追梦人物 仗剑踏歌行_Hung
2017-06-26 11:20:49

我们在 detail 视图中获取了 comment_list,把它传递给了模板的。

回复
fshgrym 仗剑踏歌行_Hung
2017-11-02 21:00:09

context

回复
sakura1357
2017-06-22 17:08:14

我的环境是Windows 10+Python3.6.1 (64位) + Django 1.10.6,runserver报错:File "F:\joe\Workspace\blogproject\blog\views.py", line 6, in
from blogproject.comments.forms import CommentForm
ModuleNotFoundError: No module named 'blogproject.comments'
但是我views.py文件里明明已经导入了这个类了,只不过要这样写才能导入: from blogproject.comments.forms import CommentForm

回复
sakura1357 sakura1357
2017-06-22 17:08:51

我也有这个类文件

回复
追梦人物 sakura1357
2017-06-22 20:35:11

你看一下 comments 目录下有没有 __init__.py 文件?

回复
sakura1357 追梦人物
2017-06-26 13:24:15

有这个文件

回复
追梦人物 sakura1357
2017-06-26 15:16:24

你可以用相对应用,from comments.form import 。。。

回复
sakura1357 追梦人物
2017-06-26 15:37:28

相对引用就直接报错了,unresolved reference 'comments'

回复
追梦人物 sakura1357
2017-06-26 19:24:12

给我看看你的项目目录结构。

回复
sakura1357 追梦人物
2017-06-27 13:59:29

我加你QQ了,你同意一下吧。

回复
rockfire sakura1357
2017-07-10 21:10:55
回复
moon8787 sakura1357
2017-07-13 17:33:08

我也有这个问题,是什么原因啊??

回复
sakura1357 moon8787
2017-08-01 10:57:06

你是用的pycharm吗,Workspace/blogproject这个目录,在pycharm里面blogproject目录上右键Mark directory as Sources Root就行了。

回复
mihelloO
2017-06-16 11:52:01

今天开始研究django-contrib-comments

回复
mihelloO mihelloO
2017-06-20 17:37:51

博主的/comments/success/ 跳到的comment的id是怎么获取?是通过获取最新的comment的id ?

回复
mihelloO mihelloO
2017-06-20 19:05:53

噢!原来是django-contrib-comments 自动的功能

回复
追梦人物 mihelloO
2017-06-20 19:35:35

嗯,好像是会自动传递 id。

回复
pursedream
2017-06-10 19:39:15

请问一下这是什么原因啊
Reverse for 'article_comment' with arguments '('',)' and keyword arguments '{}' not found. 1 pattern(s) tried: ['comment/article/(?P[0-9]+)/\('], 这个是urls的, app_name = 'comments' urlpatterns = [ url(r'^comment/article/(?P<article_pk>[0-9]+)/\)', views.article_comment, name='article_comment'),]
这个是表格的

# post保护 {% csrf_token %}
回复
追梦人物 pursedream
2017-06-10 20:00:23

看代码没有看出什么问题,看看你有没有在项目的 urls.py 中包含这个 app 的 url

回复
pursedream 追梦人物
2017-06-11 22:44:41

在主项目的urls也包含了 url(r'', include('blog.urls')),
url(r'', include('comments.urls')),

回复
yeliang
2017-06-06 21:48:11

comments.views里面form数据失效的情况下,最好代码把post.body处理下,markdown.....

回复
追梦人物 yeliang
2017-06-06 23:47:51

是的,这个地方我疏忽了,大家自己修正一下吧!

回复
yeliang 追梦人物
2017-06-07 02:25:51

博主您好我发现这个项目中,在评论数据中是无法换行的情况,您看看有没有办法可以解决

回复
追梦人物 yeliang
2017-06-07 06:03:29

你可以模板中对评论内容使用 linebreakbr 过滤器。

回复
qiqiming
2017-06-05 23:18:52

禁止访问 (403)
CSRF验证失败. 请求被中断.

回复
追梦人物 qiqiming
2017-06-05 23:19:34

什么意思呢?

回复
qiqiming 追梦人物
2017-06-05 23:37:31

已经解决了又添加了
{% csrf_token %}

回复
对AI的反义词毫无抵抗力的春哥 qiqiming
2017-06-07 16:14:36

添加之后还是无法解决

回复
qiqiming 对AI的反义词毫无抵抗力的春哥
2017-06-07 20:21:50

添加在表单里

回复
Ehco
2017-05-30 16:39:59

请问与一下博主,我们增加这个comment模块之后,detail界面没有显示评论框,必须要点击一下 发表 按钮,才会加载出评论框。

在访问 /post/ 的时候不是会执行views.detali函数,但是不会执行comments/views.post_comment函数 是这个原因吗?

应该怎么解决呢? 谢谢啦

回复
追梦人物 Ehco
2017-05-30 20:08:15

所以我们修改了detail函数,让他一加载就渲染评论表单,具体请看代码。

回复
Ehco 追梦人物
2017-05-30 20:18:27

谢谢 原来是我模板变量没有传进去,已经解决了。

回复
xgj1010
2017-05-20 14:53:03

from django.db import models

Create your models here.

class Comment(models.Model):
name = models.CharField(max_length=100)
email = models.EmailField(max_length=255)
url = models.URLField(blank=True)
text = models.TextField()
created_time = models.DateField(auto_now_add=True)

post = models.ForeignKey('blog.Post')

def __str__(self):
    return self.text[:20]

如果把created_time = models.DateTimeField(auto_now_add=True)改成created_time = models.DateField(auto_now_add=True)就会报错'datetime.date' object has no attribute 'tzinfo'
如果不改的话时间就不能精确到当前时间,请问该如何解决

回复
追梦人物 xgj1010
2017-05-20 15:00:48

如果在开发环境下,建议删掉数据库,删掉全部 migrations,然后重新 makemigrations 和 migrate。

回复
李先森李先森李先森
2017-05-20 10:49:53

我有一个疑问...为什么要让评论者手动输入一个URL呢?可不可以设置一个默认值?

回复
追梦人物 李先森李先森李先森
2017-05-20 11:09:25

这是早期互联网博客的传统做法,评论者可以在评论里留下自己的网站,以便他人访问。目前的评论系统比较少这样做了,比如我的博客评论系统需要使用社交账户登录才能评论。

回复
李先森李先森李先森 追梦人物
2017-05-20 14:26:35

明白了,谢谢!

回复
gleesu
2017-05-14 00:41:10

“如果你忘了怎么做,回这里参考再复习一下我们当初的做法吧。”链接指向的是当前界面~

回复
追梦人物 gleesu
2017-05-19 10:41:29

已全部修正,感谢☞出!

回复
gleesu
2017-05-14 00:26:10

"关于创建 app 以及 django 的目录结构前面已经有过介绍,如果你需要复习的话请[点击这里][]",点击的链接失效~

回复