当前位置:Gxlcms > Python > PythonDjango使用forms来实现评论功能

PythonDjango使用forms来实现评论功能

时间:2021-07-01 10:21:17 帮助过:85人阅读

貌似Django从版本1.6开始就放弃了对自带的comments的使用,具体原因未查,但是现在使用Django的内部的模块也可以实现评论功能,那就是借助于forms模块,下面是我的一个小例子。

环境准备
•操作系统 : windows 7 64 位旗舰版
•IDE: PyCharm 2016.1
•Python :2.7.11
•Django :1.9.6

设计

所谓设计,就是指我们将要实现的评论功能将要涉及的底层模型。我这里简单的设计如下,大家按照自己的想法,可以随意的设置,我这里的设置见models.py文件:

  1. from __future__ import unicode_literals
  2. from django.contrib import admin
  3. from django.db import models
  4. from django import forms
  5. # Create your models here.
  6. TOPIC_CHOICES = (
  7. ('level1','Bad'),
  8. ('level2','SoSo'),
  9. ('level3','Good'),
  10. )
  11. class RemarkForm(forms.Form):
  12. subject = forms.CharField(max_length=100,label='Mark Board')
  13. mail = forms.EmailField(label='email')
  14. topic = forms.ChoiceField(choices=TOPIC_CHOICES,label='choose one topic')
  15. message = forms.CharField(label='content for mark',widget=forms.Textarea)
  16. cc_myself = forms.BooleanField(required=False,label='watch this tie')
  17. class Remark(models.Model):
  18. subject = models.CharField(max_length=100)
  19. mail = models.EmailField()
  20. topic = models.CharField(max_length=100)
  21. message = models.CharField(max_length=300)
  22. cc_myself = models.BooleanField()
  23. def __unicode__(self):
  24. return self.subject
  25. class Meta:
  26. ordering = ['subject']
  27. admin.site.register([Remark,])

大家都看到了,models.py文件里面多了一个forms 的子类,这回因为我们的操作涉及到了网页表单,这样的话,最好给每一个model类创建一个Form表单类,方便从表单中获取cleaned_data。

url映射文件urls.py

这个文件比较的简单,如下:

  1. """FormRelative URL Configuration
  2. The `urlpatterns` list routes URLs to views. For more information please see:
  3. https://docs.djangoproject.com/en/1.9/topics/http/urls/
  4. Examples:
  5. Function views
  6. 1. Add an import: from my_app import views
  7. 2. Add a URL to urlpatterns: url(r'^$', views.home, name='home')
  8. Class-based views
  9. 1. Add an import: from other_app.views import Home
  10. 2. Add a URL to urlpatterns: url(r'^$', Home.as_view(), name='home')
  11. Including another URLconf
  12. 1. Import the include() function: from django.conf.urls import url, include
  13. 2. Add a URL to urlpatterns: url(r'^blog/', include('blog.urls'))
  14. """
  15. from django.conf.urls import url
  16. from django.contrib import admin
  17. from app.views import *
  18. urlpatterns = [
  19. url(r'^admin/', admin.site.urls),
  20. url(r'^remark/$',reamark),
  21. ]
  22. 视图层views.py

这个文件决定了映射文件对应的展示的视图,所以比较的重要。

  1. from django.shortcuts import render
  2. from app.models import *
  3. from django.http import *
  4. # Create your views here.
  5. # subject = models.CharField(max_length=100)
  6. # mail = models.EmailField()
  7. # topic = models.CharField(max_length=100)
  8. # message = models.CharField(max_length=300)
  9. # cc_myself = models.BooleanField()
  10. def reamark(request):
  11. if request.method =="POST":
  12. form = RemarkForm(request.POST)
  13. if form.is_valid():
  14. myremark = Remark()
  15. myremark.subject=form.cleaned_data['subject']
  16. myremark.mail = form.cleaned_data['mail']
  17. myremark.topic = form.cleaned_data['topic']
  18. myremark.message = form.cleaned_data['message']
  19. myremark.cc_myself = form.cleaned_data['cc_myself']
  20. myremark.save()
  21. # return HttpResponse("Publish Success!")
  22. else:
  23. form = RemarkForm()
  24. ctx = {
  25. 'form':form,
  26. 'ties':Remark.objects.all()
  27. }
  28. return render(request,'message.html',ctx)

模板templates/message.html

模板的使用大大的减少了数据量,而且更加灵活的实现了数据在展示层的分离,降低了模块之间的耦合性。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. <form action="." method="post">
  9. {% for field in form %}
  10. {% csrf_token %}
  11. <div>
  12. {{ field.label_tag }}:{{ field }}
  13. {{ field.errors }}
  14. </div>
  15. {% endfor %}
  16. <div>
  17. <input type="submit" value="Remark">
  18. </div>
  19. </form>
  20. <hr>
  21. {% for tie in ties %}
  22. <div>
  23. <ul>
  24. <li>{{ tie.subject }}</li>
  25. <li>{{ tie.mail}}</li>
  26. <li>{{ tie.topic}}</li>
  27. <li>{{ tie.message }}</li>
  28. <li>{{ tie.cc_myself }}</li>
  29. </ul>
  30. <hr>
  31. </div>
  32. {% endfor%}
  33. </body>
  34. </html>

注意补办标签和模板变量都是我们在views.py的remark方法中声明过的了,所以可以直接的使用。

初始化数据库

这里使用的是sqlite数据库,在settings.py文件中的配置如下;

  1. # Database
  2. # https://docs.djangoproject.com/en/1.9/ref/settings/#databases
  3. DATABASES = {
  4. 'default': {
  5. 'ENGINE': 'django.db.backends.sqlite3',
  6. 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
  7. }
  8. }

然后在terminal 环境下,输入下面的几条命令:

  1. // 创建数据库表结构
  2. python manage.py makemigrations
  3. python manage.py migrate
  4. // 按照提示进行操作即可,目的是为了创建一个超级管理员
  5. python createsuperuser
  6. //在自带的开发服务器上运行我们的项目
  7. python manage.py runserver

调试验证

这里我们在浏览器下输入
127.0.0.1:8000/admin
就可以看到下面

Python Django使用forms来实现评论功能

然后输入127.0.0.1:8000/remark

Python Django使用forms来实现评论功能

数据库端:

Python Django使用forms来实现评论功能

这样,除了没有美化界面,其余的都完成了呢。

总结

这里虽然是个很简单的小例子,但是我也从中发现了自己的一些概念上的问题,比如说对于模型设计的不合理,因为没有评论时间,这就显得很尴尬了。

然后是

  1. if request.method =="POST":
  2. form = RemarkForm(request.POST)
  3. if form.is_valid():
  4. myremark = Remark()
  5. myremark.subject=form.cleaned_data['subject']
  6. myremark.mail = form.cleaned_data['mail']
  7. myremark.topic = form.cleaned_data['topic']
  8. myremark.message = form.cleaned_data['message']
  9. myremark.cc_myself = form.cleaned_data['cc_myself']
  10. myremark.save()
  11. # return HttpResponse("Publish Success!")
  12. else:
  13. form = RemarkForm()
  14. ctx = {
  15. 'form':form,
  16. 'ties':Remark.objects.all()
  17. }
  18. return render(request,'message.html',ctx)

这段代码,对应的表单中的action是.这就说明表单提交到了本页面,也就实现了表单数据的评论,这一点很是巧妙。而且使用Django的这一个特点还有一个好处,那就是在不进行手动刷新页面的情况下,仍然可以实现评论的异步加载。

最后,就是模型中Remark模型和RemarkForm表单属性的一致性。这一点应该尤其的注意哦!

好了,今天就介绍到这里吧,由于本人能力一般,代码或者逻辑有错的地方,欢迎大家批评指正!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持PHP中文网。

更多Python Django使用forms来实现评论功能相关文章请关注PHP中文网!

人气教程排行