Python Django使用forms來實現評論功能

Python Django使用forms來實現評論功能

貌似Django從版本1.6開始就放棄了對自帶的comments的使用,具體原因未查,但是現在使用Django的內部的模組也可以實現評論功能,那就是藉助於forms模組,下面是我的一個小例子。

環境準備
 •作業系統 : windows 7 64 位旗艦版
 •IDE: PyCharm 2016.1
 •Python :2.7.11
 •Django :1.9.6

設計

所謂設計,就是指我們將要實現的評論功能將要涉及的底層模型。我這裡簡單的設計如下,大家按照自己的想法,可以隨意的設定,我這裡的設定見models.py檔案:


from __future__ import unicode_literals
from django.contrib import admin
from django.db import models
from django import forms
# Create your models here.
TOPIC_CHOICES = (
('level1','Bad'),
('level2','SoSo'),
('level3','Good'),
)
class RemarkForm(forms.Form):
subject = forms.CharField(max_length=100,label='Mark Board')
mail = forms.EmailField(label='email')
topic = forms.ChoiceField(choices=TOPIC_CHOICES,label='choose one topic')
message = forms.CharField(label='content for mark',widget=forms.Textarea)
cc_myself = forms.BooleanField(required=False,label='watch this tie')
class Remark(models.Model):
subject = models.CharField(max_length=100)
mail = models.EmailField()
topic = models.CharField(max_length=100)
message = models.CharField(max_length=300)
cc_myself = models.BooleanField()
def __unicode__(self):
return self.subject
class Meta:
ordering = ['subject']
admin.site.register([Remark,])

大家都看到了,models.py檔案裡面多了一個forms 的子類,這回因為我們的操作涉及到了網頁表單,這樣的話,最好給每一個model類建立一個Form表單類,方便從表單中獲取cleaned_data。 

url對映檔案urls.py

這個檔案比較的簡單,如下:


"""FormRelative URL Configuration
The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/1.9/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: url(r'^$', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: url(r'^$', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.conf.urls import url, include
2. Add a URL to urlpatterns: url(r'^blog/', include('blog.urls'))
"""
from django.conf.urls import url
from django.contrib import admin
from app.views import *
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^remark/$',reamark),
]

 檢視層views.py

這個檔案決定了對映檔案對應的展示的檢視,所以比較的重要。


from django.shortcuts import render
from app.models import *
from django.http import *
# Create your views here.
# subject = models.CharField(max_length=100)
#   mail = models.EmailField()
#   topic = models.CharField(max_length=100)
#   message = models.CharField(max_length=300)
#   cc_myself = models.BooleanField()
def reamark(request):
if request.method =="POST":
form = RemarkForm(request.POST)
if form.is_valid():
myremark = Remark()
myremark.subject=form.cleaned_data['subject']
myremark.mail = form.cleaned_data['mail']
myremark.topic = form.cleaned_data['topic']
myremark.message = form.cleaned_data['message']
myremark.cc_myself = form.cleaned_data['cc_myself']
myremark.save()
# return HttpResponse("Publish Success!")
else:
form = RemarkForm()
ctx = {
'form':form,
'ties':Remark.objects.all()
}
return render(request,'message.html',ctx)

模板templates/message.html

模板的使用大大的減少了資料量,而且更加靈活的實現了資料在展示層的分離,降低了模組之間的耦合性。


<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="." method="post">
{% for field in form %}
{% csrf_token %}
<div>
{{ field.label_tag }}:{{ field }}
{{ field.errors }}
</div>
{% endfor %}
<div>
<input type="submit" value="Remark">
</div>
</form>
<hr>
{% for tie in ties %}
<div>
<ul>
<li>{{ tie.subject }}</li>
<li>{{ tie.mail}}</li>
<li>{{ tie.topic}}</li>
<li>{{ tie.message }}</li>
<li>{{ tie.cc_myself }}</li>
</ul>
<hr>
</div>
{% endfor%}
</body>
</html>

注意補辦標籤和模板變數都是我們在views.py的remark方法中宣告過的了,所以可以直接的使用。 

初始化資料庫

這裡使用的是sqlite資料庫,在settings.py檔案中的配置如下;


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

然後在terminal 環境下,輸入下面的幾條命令:


// 建立資料庫表結構
python manage.py makemigrations
python manage.py migrate
// 按照提示進行操作即可,目的是為了建立一個超級管理員
python createsuperuser
//在自帶的開發伺服器上執行我們的專案
python manage.py runserver

除錯驗證

這裡我們在瀏覽器下輸入
127.0.0.1:8000/admin
就可以看到下面

後臺管理員頁面

然後輸入127.0.0.1:8000/remark

評論完成

資料庫端:

資料庫段資料

這樣,除了沒有美化介面,其餘的都完成了呢。

總結

這裡雖然是個很簡單的小例子,但是我也從中發現了自己的一些概念上的問題,比如說對於模型設計的不合理,因為沒有評論時間,這就顯得很尷尬了。

然後是


if request.method =="POST":
form = RemarkForm(request.POST)
if form.is_valid():
myremark = Remark()
myremark.subject=form.cleaned_data['subject']
myremark.mail = form.cleaned_data['mail']
myremark.topic = form.cleaned_data['topic']
myremark.message = form.cleaned_data['message']
myremark.cc_myself = form.cleaned_data['cc_myself']
myremark.save()
# return HttpResponse("Publish Success!")
else:
form = RemarkForm()
ctx = {
'form':form,
'ties':Remark.objects.all()
}
return render(request,'message.html',ctx)

這段程式碼,對應的表單中的action是.這就說明表單提交到了本頁面,也就實現了表單資料的評論,這一點很是巧妙。而且使用Django的這一個特點還有一個好處,那就是在不進行手動重新整理頁面的情況下,仍然可以實現評論的非同步載入。

最後,就是模型中Remark模型和RemarkForm表單屬性的一致性。這一點應該尤其的注意哦!

好了,今天就介紹到這裡吧,由於本人能力一般,程式碼或者邏輯有錯的地方,歡迎大家批評指正!