![Django 3.0入门与实践](https://wfqqreader-1252317822.image.myqcloud.com/cover/246/36862246/b_36862246.jpg)
3.12 HTML表单
HTML表单是客户端与服务器端进行交互的重要方式,在讲解HTML表单之前先进行必要的准备工作。
步骤1:将Choice模型注册到admin网站,修改polls/admin.py。
from django.contrib import admin from .models import Question, Choice
admin.site.register(Question) admin.site.register(Choice)
步骤2:登录admin后台,为问卷添加选项。
单击Add按钮,进入添加问卷选项页面,效果如下图所示。
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P36_18233.jpg?sign=1739409198-c6WK5fxR5mssqwR5Lc0lLyidHgbxw9Vh-0-d78eed278c340023d37222db296b7d37)
添加3个选项,效果如下面三幅图所示。
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P36_18240.jpg?sign=1739409198-jR29zb9DNRZoMZesmPnAoDhlhBSjHyyx-0-1adc4e514771484daf61af260f7a7a33)
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P37_18735.jpg?sign=1739409198-oqaj6rDbjTriB7SLOf67fCLL1V8I1396-0-530958c27a463e125639c089509f7d3c)
完成准备工作后,继续修改polls/detail.html模板,为其添加HTML表单用于提交信息,新模板如下:
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P37_149269.jpg?sign=1739409198-HVWZSPJFU2c5Ns03svYIe0WU0uwFqx0J-0-ee68818ec83d6aed6c2914ff54d30f8d)
代码分析:
在问卷详情页显示问卷相关选项,并为每一个选项添加单选按钮(radio)。
表单的处理页用url模板标签表示"{% url 'polls:vote' question.id %}",表单以post的方式提交。
forloop.counter标签用于记录循环次数。
由于当前表单使用post方式提交数据,需要防止伪造的跨站点请求,表单中的{% csrf_token %}标签就可以解决这类问题。
接下来创建一个视图来接收并处理表单提交的信息:
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P37_149273.jpg?sign=1739409198-ND164Juzu0o0vuWUcAkerLflIR5FwVtb-0-406741ceeeae452f0ff76b4020f00f1f)
代码分析:
request.POST是一个类字典对象,以便通过关键字的名字获取提交的数据。如果表单提交的信息中不存在则抛出KeyError。
信息处理结束后,使用HttpResponseRedirect方法跳转到新的页面以免用户单击浏览器后退按钮导致重新提交表单,这是一个很好的编程习惯。
为了防止在HttpResponseRedirect方法中使用URL硬编码,使用reverse()方法强制调用URL名字并且接收必要参数,而不是直接使用URL。
由于提交问卷后页面会跳转到结果页,因此需要修改results视图:
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P38_149278.jpg?sign=1739409198-Xuw85B9DRko1xR2Ndb9uZw6JK8rxgOUm-0-4dc9ad321cbe9f4729925016a9830e26)
新建polls/results.html模板并添加以下代码:
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P38_149280.jpg?sign=1739409198-7uKkvuAdAyyjTdr1Fuv2TvrJEY3NBojG-0-f40cb6f503160c33ed073f4e48d01f34)
好了,到目前为止一个简单的投票系统就做好了,登录网站测试一下。
打开投票系统网址:http://127.0.0.1:8000/polls/,效果如下图所示。
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P38_19217.jpg?sign=1739409198-XrwUfBfgW6KS53mdiYxsAsKSlgahCXHu-0-0fea9c8ec77e55e3c8a329441061a2de)
单击问卷链接,效果如下图所示。
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P39_19671.jpg?sign=1739409198-MIPtuUH4rglTTzuriTLFckswjSCRzW8E-0-66fb2f3b7aea3cb73b32028c291e4f19)
选择任意选项,单击“提交”按钮,效果如下图所示。
![](https://epubservercos.yuewen.com/B89DD0/19549641008916106/epubprivate/OEBPS/Images/Figure-P39_19678.jpg?sign=1739409198-SdMeDjZHa3binfu3ira9YBxKsoSVMkgo-0-6a257a1a38265317b731ee61bd7e0a7a)