Python Django使用forms來實(shí)現(xiàn)評(píng)論功能
貌似Django從版本1.6開始就放棄了對(duì)自帶的comments的使用,具體原因未查,但是現(xiàn)在使用Django的內(nèi)部的模塊也可以實(shí)現(xiàn)評(píng)論功能,那就是借助于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)的評(píng)論功能將要涉及的底層模型。我這里簡(jiǎ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è)文件比較的簡(jiǎn)單,如下:
"""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è)文件決定了映射文件對(duì)應(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)簽和模板變量都是我們?cè)趘iews.py的remark方法中聲明過的了,所以可以直接的使用。
初始化數(shù)據(jù)庫(kù)
這里使用的是sqlite數(shù)據(jù)庫(kù),在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ù)庫(kù)表結(jié)構(gòu) python manage.py makemigrations python manage.py migrate // 按照提示進(jìn)行操作即可,目的是為了創(chuàng)建一個(gè)超級(jí)管理員 python createsuperuser //在自帶的開發(fā)服務(wù)器上運(yùn)行我們的項(xiàng)目 python manage.py runserver
調(diào)試驗(yàn)證
這里我們?cè)跒g覽器下輸入
127.0.0.1:8000/admin
就可以看到下面
然后輸入127.0.0.1:8000/remark
數(shù)據(jù)庫(kù)端:
這樣,除了沒有美化界面,其余的都完成了呢。
總結(jié)
這里雖然是個(gè)很簡(jiǎn)單的小例子,但是我也從中發(fā)現(xiàn)了自己的一些概念上的問題,比如說對(duì)于模型設(shè)計(jì)的不合理,因?yàn)闆]有評(píng)論時(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)
這段代碼,對(duì)應(yīng)的表單中的action是.這就說明表單提交到了本頁面,也就實(shí)現(xiàn)了表單數(shù)據(jù)的評(píng)論,這一點(diǎn)很是巧妙。而且使用Django的這一個(gè)特點(diǎn)還有一個(gè)好處,那就是在不進(jìn)行手動(dòng)刷新頁面的情況下,仍然可以實(shí)現(xiàn)評(píng)論的異步加載。
最后,就是模型中Remark模型和RemarkForm表單屬性的一致性。這一點(diǎn)應(yīng)該尤其的注意哦!
好了,今天就介紹到這里吧,由于本人能力一般,代碼或者邏輯有錯(cuò)的地方,歡迎大家批評(píng)指正!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python pickle類庫(kù)介紹(對(duì)象序列化和反序列化)
這篇文章主要介紹了Python pickle類庫(kù)介紹(對(duì)象序列化和反序列化),本文講解了pickle庫(kù)的作用、pickle的運(yùn)行過程、使用實(shí)例、修改picklable類型的默認(rèn)行為等內(nèi)容,需要的朋友可以參考下2014-11-11opencv形態(tài)學(xué)中的孔洞填充詳細(xì)圖解
我們?cè)谶M(jìn)行圖像分割后,分割結(jié)果有時(shí)會(huì)有一些小孔洞,如圖1所示,其中黑白兩色表示兩種不同的類別。一般情況下,這些孔洞屬于錯(cuò)分情況,為了優(yōu)化結(jié)果,我們通常對(duì)這些孔洞進(jìn)行填充。今天我們就用python語言基于OpenCV實(shí)現(xiàn)孔洞填充2022-10-10Python使用BeautifulSoup庫(kù)解析網(wǎng)頁
在Python的網(wǎng)絡(luò)爬蟲中,網(wǎng)頁解析是一項(xiàng)重要的技術(shù)。而在眾多的網(wǎng)頁解析庫(kù)中,BeautifulSoup庫(kù)憑借其簡(jiǎn)單易用而廣受歡迎,在本篇文章中,我們將學(xué)習(xí)BeautifulSoup庫(kù)的基本用法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2023-08-08基于Python工具使用Web3.py以太坊智能合約開發(fā)的方法
智能合約是區(qū)塊鏈技術(shù)的核心應(yīng)用之一,它允許在沒有中介的情況下,通過代碼自動(dòng)執(zhí)行合同條款,以太坊是目前最流行的智能合約平臺(tái)之一,而Web3.py是用于與以太坊區(qū)塊鏈交互的Python庫(kù),本文將詳細(xì)介紹如何使用Web3.py進(jìn)行以太坊智能合約的開發(fā),需要的朋友可以參考下2024-11-11升級(jí)anaconda中python到3.10版本的簡(jiǎn)單步驟
anaconda是一個(gè)非常好用的python發(fā)行版本,其中包含了大部分常用的庫(kù),下面這篇文章主要給大家介紹了關(guān)于升級(jí)anaconda中python到3.10版本的簡(jiǎn)單步驟,需要的朋友可以參考下2024-03-03Python利用全連接神經(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