>백엔드 개발 >파이썬 튜토리얼 >Python Django는 양식을 사용하여 주석 기능을 구현합니다.

Python Django는 양식을 사용하여 주석 기능을 구현합니다.

高洛峰
高洛峰원래의
2017-01-21 14:10:362169검색

Django는 1.6 버전부터 자체 주석 사용을 포기한 것으로 보입니다. 구체적인 이유는 조사되지 않았지만 이제 Django 내부 모듈, 즉 다음의 도움을 받아 주석 기능을 구현할 수도 있습니다. form 모듈입니다. 여기 내 작은 예가 있습니다.

환경 준비
•운영 체제: 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 파일 양식의 추가 하위 클래스가 있습니다. 이번에는 작업에 웹 양식이 포함되기 때문에 이 경우 양식에서 clean_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)

templatetemplate/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>

reissue 태그와 템플릿 변수는 views.py의 Remark 메소드에 선언되어 있어 바로 사용할 수 있으니 참고하세요.

데이터베이스 초기화

여기서는 sqlite 데이터베이스를 사용하며, settings.py 파일의 구성은 다음과 같습니다.

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

그런 다음 터미널 환경에서 다음 명령을 입력합니다.

// 创建数据库表结构
python manage.py makemigrations
 
python manage.py migrate
 
// 按照提示进行操作即可,目的是为了创建一个超级管理员
python createsuperuser
 
//在自带的开发服务器上运行我们的项目
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来实现评论功能

이렇게 하면 인터페이스를 아름답게 하는 것 빼고는 모두 완성되었습니다.

요약

아주 간단한 예이지만, 코멘트할 시간이 없어서 모델 디자인이 불합리한 등 저만의 개념적인 문제도 발견했습니다.

그리고

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

이 코드는 양식의 해당 작업이 이 페이지에 제출되고 양식 데이터에 대한 댓글이 있음을 의미합니다. 깨달았습니다. 이것은 매우 영리합니다. 그리고 Django의 이 기능을 사용하면 페이지를 수동으로 새로 고치지 않고도 주석을 비동기식으로 로드할 수 있다는 또 다른 이점이 있습니다.

마지막으로 Remark 모델과 모델 내 RemarkForm 양식 속성의 일관성입니다. 이것에 특별한주의를 기울여야합니다!

자, 오늘은 여기까지입니다. 저의 평균적인 능력으로 인해 코드나 로직에 오류가 있으면 누구든 비판하고 수정해도 좋습니다!

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되기를 바랍니다. 또한 모든 분들이 PHP 중국어 웹사이트를 지지해주시기를 바랍니다.

양식을 사용하여 주석 기능을 구현하는 Python Django에 관한 더 많은 기사를 보려면 PHP 중국어 사이트를 주목하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.