功能:在A网页提交一个评论Forms_B,提交之后自动刷新页面,能够显示刚刚的画面
思路:利用一个已经创建的表单,通过视图让其在网页中表现出来,填写玩信息之后提交,会提交到一个新的视图里面去做接受,接受之后重定向到另外一个地方。(是什么地方)
步骤:

一、在app里面的forms.py里面新建一个表单:

 #blog/forms.py
from django import forms class CommentForm(forms.Form):
'''
评论表单
'''
#author使用CharField字段,字段内使用三个参数,分别是widget, max_length, error_messages
author = forms.CharField(
#为各个需要渲染的字段指定渲染成什么Html组件,主要是为了添加css样式
widget=forms.TextInput(attrs={"id": "author", "class": "comment_input",
"required": "required","size": "", "tabindex": ""}),
max_length=50,error_messages={"required":"username不能为空",})
email = forms.EmailField(widget=forms.TextInput(attrs={"id":"email","type":"email","class": "comment_input",
"required":"required","size":"", "tabindex":""}),
max_length=50, error_messages={"required":"email不能为空",})
url = forms.URLField(widget=forms.TextInput(attrs={"id":"url","type":"url","class": "comment_input",
"size":"", "tabindex":""}),
max_length=100, required=False)
comment = forms.CharField(widget=forms.Textarea(attrs={"id":"comment","class": "message_input",
"required": "required", "cols": "",
"rows": "", "tabindex": ""}),
error_messages={"required":"评论不能为空",})
article = forms.CharField(widget=forms.HiddenInput())

二、在文章详情视图里面让接入表单

 def article(request):
# 评论表单
comment_form = CommentForm({'author': request.user.username,
'email': request.user.email,
'url': request.user.url,
'article': id} if request.user.is_authenticated() else{'article': id})
return render(request, 'article.html', locals())

三、在模板中将视图体现出来

     <form action="{% url 'comment_post' %}" method="post">
{% csrf_token %}
<p>{{ comment_form.author }}
<label for="author">Name (required)</label></p> <p>{{ comment_form.email }}
<label for="email">Email (Will NOT be published) (required)</label></p> <p>{{ comment_form.url }}
<label for="url">URL</label></p> <p>{{ comment_form.comment }}</p> <p>
{{ comment_form.article }}
<input name="submit" type="submit" id="submit" tabindex="5" value="Submit" class="button" />
</p>
</form>

四、模板中的提交链接到URL中

url(r'^comment/post/$', comment_post, name='comment_post'),

五、在视图中接收提交的内容,并且重定向

 # 提交评论
def comment_post(request):
try:
#获取表单内填入的内容
comment_form=CommentForm(request.POST)
#进行验证的第一个表单验证
if comment_form.is_vaild():
#获取表单信息
#cleaned_data()用来把接收到的文字清洗为符合django的字符
#create是一个在一步操作中同时创建对象并且保存的便捷方法。
comment=Comment.objects.create(username=comment_form.cleaned_data["author"],
eamil=comment_form.cleaned_data["email"],
url=comment_form.cleaned_data["url"],
content=comment_form.cleaned_data["comment"],
article_id=comment_form.cleaned_data["article"],
#如果用户已经登录,则获取已经登录的用户,非登录用户将返回None
#此处用的if语句有些特殊。
user=request.user if request.user.is_authenticated() else None)
comment.save() #保存实例
else:
return render(request, "failure.html", {"reason":comment_form.erros})
except Exception as e:
logger.error(e)
#重定向到进来之前的网页
#HTTP_REFERER是http的头文件的一部分,当浏览器向web服务器发送请求的时候,一般会带上Referer,告诉服务器我是从哪个页面链接过来的,服务器借此获得一些信息用于处理。
return redirect(request.META['HTTP_REFERER'])
'''
#判断用户是不是登录,也可以用这个写法,79行的写法也很简单
if request.user.is_authenticated(): #判断用户是否登录
user=request.user #获取已经登录的用户
else:
user=request.user #非登录用户将返回AnonymousUser
'''

request.META是一个里面包含了所有本次http请求的Header信息,比如用户IP,用户Agent
常见的键值有:
HTTP_REFERER,进站前链接网页,如果有的话。
redirec是重定向
redirec是重定向

Django博客功能实现—文章评论功能的更多相关文章

  1. 为hexo博客添加基于gitment评论功能

    关于gitment gitment其实就是利用你的代码仓库的Issues,来实现评论.每一篇文章对应该代码仓库中的 一个Issues,Issues中的评论对应你的博客每篇文章中的评论.如果你是用git ...

  2. Django 博客单元测试:测试评论应用

    作者:HelloGitHub-追梦人物 文中所涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 评论应用的测试和博客应用测试的套路是一样的. 先来建立测试文件的目录结构.首先在 c ...

  3. Django(博客系统):文章内容使用django-ckeditor、文章简介使用django-tinymce

    文章内容使用django-ckeditor 1)安装django-ckeditor pip install django-ckeditorpip install Pillow 2)在settings. ...

  4. Django1.9开发博客(7)- 实现功能

    到目前为止我们已经完成了一个django应用的所有基础部分. 包括url配置.视图.模型和模板.接下来开始继续完善我们的博客系统了. 首先我们需要一个显示每篇文章的详细页面,对不? 文章详情 对于首页 ...

  5. django博客项目8:文章详情页

    首页展示的是所有文章的列表,当用户看到感兴趣的文章时,他点击文章的标题或者继续阅读的按钮,应该跳转到文章的详情页面来阅读文章的详细内容.现在让我们来开发博客的详情页面,有了前面的基础,开发流程都是一样 ...

  6. 为你的CSDN博客添加CNZZ流量统计功能

    一.流量统计介绍 流量统计是指通过各种科学的方式,准确的纪录来访某一页面的访问者的流量信息,目前而言,必须具备可以统计. 1.简介 统计独立的访问者数量(独立用户.独立访客): 可以统计独立的IP地址 ...

  7. django博客项目6:Django Admin 后台发布文章

    在此之前我们完成了 Django 博客首页视图的编写,我们希望首页展示发布的博客文章列表,但是它却抱怨:暂时还没有发布的文章!如它所言,我们确实还没有发布任何文章,本节我们将使用 Django 自带的 ...

  8. Django博客开发实践,初学者开发经验

    python,Django初学者,开发简易博客,做了一下笔记,记录了开发的过程,功力浅薄,仅供初学者互相 交流,欢迎意见建议.具体链接:Django博客开发实践(一)--分析需求并创建项目 地址:ht ...

  9. django博客项目5:博客首页视图(2)

    真正的 Django 博客首页视图 在此之前我们已经编写了 Blog 的首页视图,并且配置了 URL 和模板,让 Django 能够正确地处理 HTTP 请求并返回合适的 HTTP 响应.不过我们仅仅 ...

随机推荐

  1. [示例] Firemonkey 不规则按钮实做

    利用 Firemonkey 控件的组合及可塑性,可以做出千变万化的效果及功能,下面展示一个不规则按钮的实做: 效果图: 实做方法: 开一个新工程 Multi-Device Application 放一 ...

  2. 从零开始学 Java - Windows 下安装 JDK

    关于未来 "我要死在火星.在我死去的时候能够想着人类能有一个美好的未来--有可持续的能源,同时能够殖民其他的星球来避免人类灭绝的最坏可能." 官网下载 直接打开官网:http:// ...

  3. MVC基础

    一.简介 MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑.数据.界面显示分离的方 ...

  4. 使用hovertree菜单作为后台导航

    hovertree是一个jquery菜单插件,官方网址:http://keleyi.com/jq/hovertree/ ,可以登录该网址体验效果. 0.1.3版本:http://keleyi.com/ ...

  5. jquery自定义插件结合baiduTemplate.js实现异步刷新(附源码)

    上一篇记录了BaiduTemplate模板引擎使用示例附源码,在此基础上对使用方法进行了封装 自定义插件jajaxrefresh.js 代码如下: //闭包限定命名空间 (function ($) { ...

  6. 又到周末了,我们一起来研究【浏览器如何检测是否安装app】吧

    前言 扯淡 这个月比较倒霉,我送了女朋友一台笔记本电脑作为生日礼物,结果15天一过电脑就坏了,悲剧的我还把电脑盒子给扔了!淘宝不给换更不给退 于是被女朋友臭骂了一过星期后,今天本来在公司有任务的,但是 ...

  7. ArcGIS中国工具应用:固定比例尺固定纸张批量打印

    ArcGIS中国工具应用:固定比例尺固定纸张批量打印 下载地址:http://files.cnblogs.com/files/gisoracle/a3batchprint.zip 固定A3,比例尺1: ...

  8. How to Operate SharePoint User Alerts with PowerShell

    When you migrate list or site, the user alerts in the site will not be migrated together with the co ...

  9. iOS之清除缓存

    //清除缓存按钮的点击事件 - (void)putBufferBtnClicked:(UIButton *)btn{ CGFloat size = [self folderSizeAtPath:NSS ...

  10. Android 一个对sharedpreferences 数据进行加密的开源库

    1.项目地址 https://github.com/iamMehedi/Secured-Preference-Store 2.使用方法 2.1.存数据 //存数据 SecuredPreferenceS ...