Python Django使用forms來實(shí)現(xiàn)評論功能
貌似Django從版本1.6開始就放棄了對自帶的comments的使用,具體原因未查,但是現(xiàn)在使用Django的內(nèi)部的模塊也可以實(shí)現(xiàn)評論功能,那就是借助于forms模塊,下面是我的一個(gè)小例子。
環(huán)境準(zhǔn)備
•操作系統(tǒng) : windows 7 64 位旗艦版
•IDE: PyCharm 2016.1
•Python :2.7.11
•Django :1.9.6
設(shè)計(jì)
所謂設(shè)計(jì),就是指我們將要實(shí)現(xiàn)的評論功能將要涉及的底層模型。我這里簡單的設(shè)計(jì)如下,大家按照自己的想法,可以隨意的設(shè)置,我這里的設(shè)置見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文件里面多了一個(gè)forms 的子類,這回因?yàn)槲覀兊牟僮魃婕暗搅司W(wǎng)頁表單,這樣的話,最好給每一個(gè)model類創(chuàng)建一個(gè)Form表單類,方便從表單中獲取cleaned_data。
url映射文件urls.py
這個(gè)文件比較的簡單,如下:
"""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
這個(gè)文件決定了映射文件對應(yīng)的展示的視圖,所以比較的重要。
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
模板的使用大大的減少了數(shù)據(jù)量,而且更加靈活的實(shí)現(xiàn)了數(shù)據(jù)在展示層的分離,降低了模塊之間的耦合性。
<!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>
注意補(bǔ)辦標(biāo)簽和模板變量都是我們在views.py的remark方法中聲明過的了,所以可以直接的使用。
初始化數(shù)據(jù)庫
這里使用的是sqlite數(shù)據(jù)庫,在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 環(huán)境下,輸入下面的幾條命令:
// 創(chuàng)建數(shù)據(jù)庫表結(jié)構(gòu) python manage.py makemigrations python manage.py migrate // 按照提示進(jìn)行操作即可,目的是為了創(chuàng)建一個(gè)超級管理員 python createsuperuser //在自帶的開發(fā)服務(wù)器上運(yùn)行我們的項(xiàng)目 python manage.py runserver
調(diào)試驗(yàn)證
這里我們在瀏覽器下輸入
127.0.0.1:8000/admin
就可以看到下面

然后輸入127.0.0.1:8000/remark

數(shù)據(jù)庫端:

這樣,除了沒有美化界面,其余的都完成了呢。
總結(jié)
這里雖然是個(gè)很簡單的小例子,但是我也從中發(fā)現(xiàn)了自己的一些概念上的問題,比如說對于模型設(shè)計(jì)的不合理,因?yàn)闆]有評論時(shí)間,這就顯得很尷尬了。
然后是
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)
這段代碼,對應(yīng)的表單中的action是.這就說明表單提交到了本頁面,也就實(shí)現(xiàn)了表單數(shù)據(jù)的評論,這一點(diǎn)很是巧妙。而且使用Django的這一個(gè)特點(diǎn)還有一個(gè)好處,那就是在不進(jìn)行手動刷新頁面的情況下,仍然可以實(shí)現(xiàn)評論的異步加載。
最后,就是模型中Remark模型和RemarkForm表單屬性的一致性。這一點(diǎn)應(yīng)該尤其的注意哦!
好了,今天就介紹到這里吧,由于本人能力一般,代碼或者邏輯有錯(cuò)的地方,歡迎大家批評指正!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
opencv形態(tài)學(xué)中的孔洞填充詳細(xì)圖解
我們在進(jìn)行圖像分割后,分割結(jié)果有時(shí)會有一些小孔洞,如圖1所示,其中黑白兩色表示兩種不同的類別。一般情況下,這些孔洞屬于錯(cuò)分情況,為了優(yōu)化結(jié)果,我們通常對這些孔洞進(jìn)行填充。今天我們就用python語言基于OpenCV實(shí)現(xiàn)孔洞填充2022-10-10
Python使用BeautifulSoup庫解析網(wǎng)頁
在Python的網(wǎng)絡(luò)爬蟲中,網(wǎng)頁解析是一項(xiàng)重要的技術(shù)。而在眾多的網(wǎng)頁解析庫中,BeautifulSoup庫憑借其簡單易用而廣受歡迎,在本篇文章中,我們將學(xué)習(xí)BeautifulSoup庫的基本用法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2023-08-08
基于Python工具使用Web3.py以太坊智能合約開發(fā)的方法
智能合約是區(qū)塊鏈技術(shù)的核心應(yīng)用之一,它允許在沒有中介的情況下,通過代碼自動執(zhí)行合同條款,以太坊是目前最流行的智能合約平臺之一,而Web3.py是用于與以太坊區(qū)塊鏈交互的Python庫,本文將詳細(xì)介紹如何使用Web3.py進(jìn)行以太坊智能合約的開發(fā),需要的朋友可以參考下2024-11-11
Python利用全連接神經(jīng)網(wǎng)絡(luò)求解MNIST問題詳解
這篇文章主要介紹了Python利用全連接神經(jīng)網(wǎng)絡(luò)求解MNIST問題,結(jié)合實(shí)例形式詳細(xì)分析了單隱藏層神經(jīng)網(wǎng)絡(luò)與多層神經(jīng)網(wǎng)絡(luò),以及Python全連接神經(jīng)網(wǎng)絡(luò)求解MNIST問題相關(guān)操作技巧,需要的朋友可以參考下2020-01-01

