HTML的form表單和django的form表單
django的表單系統(tǒng),分2種
- 基于django.forms.Form的所有表單類的父類
- 基于django.forms.ModelForm,可以和模型類綁定的Form
直接用原生的form表單,也可以直接用,較麻煩,
django的form表單,也可用可不要,
在views里創(chuàng)建一個類,繼承了forms.Form ,每個字段就是一個輸入框,
#-----
#django 的form表單
from django import forms
class MyForm(forms.Form):
#forms對應的是前端的form表單,form 表單要驗證的字段
#都與校驗有關系,與數(shù)據庫沒有關系
#封裝性強,可以 在前端指定顯示那些字段,label 是顯示指定的數(shù)據,
user = forms.CharField(label="用戶名")#輸入的用戶名,
age = forms.IntegerField(label="年齡")
email = forms.EmailField()
#form注冊
def reg2(request):
# 實列化出一個form對象,傳到前端
form_obj = MyForm()
return render(request,"reg2.html",{"form_obj":form_obj})
在前端新建一個注冊頁面,前端渲染表單,是后端表單類實例出來的對象,用對象調用每個字段,
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h3>form表單使用</h3>
<form action="/reg2/" method="post">
{# 渲染從后端傳來的變量,as_p 是段落#}
{% csrf_token %}
{# {{ form_obj.as_p }}#}
<p>姓名{{ form_obj.user }}</p>
<p>年齡{{ form_obj.age }}</p>
<p>郵箱{{ form_obj.email }}</p>
</form>
</body>
</html>
可以從瀏覽器的檢查元素中看到,瀏覽器自動添加了一些東西,
<body> <h3>form表單使用</h3> <form action="/reg2/" method="post"> <input name="csrfmiddlewaretoken" value="GyY3KE5uM7HeErOEZ8OQFwUJYQYaknrOmavdmfufBuVOHdDSWfeHDyt2pjXarGAV" type="hidden"> <p>姓名<input name="user" required="" id="id_user" type="text"></p> <p>年齡<input name="age" required="" id="id_age" type="number"></p> <p>郵箱<input name="email" required="" id="id_email" type="email"></p> </form> </body>
如果在前端頁面隨便輸入就提交,前端會做校驗,這都是瀏覽器做的校驗,

可以自己定制,字段的錯誤信息提示,和顯示信息,
#django 的form表單
from django import forms
class MyForm(forms.Form):
#forms對應的是前端的form表單,form 表單要驗證的字段
#都與校驗有關系,與數(shù)據庫沒有關系
#封裝性強,可以 在前端指定顯示那些字段,label 是顯示指定的數(shù)據,require 是必須填寫的,
user = forms.CharField(label="用戶名",min_length=5,max_length=8)#輸入的用戶名,
age = forms.IntegerField(label="年齡",error_messages={"required":"必填",})
email = forms.EmailField()
#form注冊
def reg2(request):
errors_obj = " "
if request.method == "POST":
form_post = MyForm(request.POST)#拿到請求的所有數(shù)據
if form_post.is_valid():#判斷數(shù)據是否合法,返回布爾值,
print("data",form_post.cleaned_data)#獲取數(shù)據,得到一個字典格式,
#添加數(shù)據庫
# User.objects.create_user()
# 實列化出一個form對象,傳到前端
#如果是輸入不合格式的信息,錯誤信息,
else:
#獲取錯誤信息
errors_obj = form_post.errors
# print("error",form_post.errors["user"][0])
# print("error",form_post.errors["age"])
# print("error",type(form_post.errors))#字典類型,
form_obj = MyForm()
return render(request,"reg2.html",{"form_obj":form_obj,"errors_obj":errors_obj})
在前端頁面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h3>form表單使用</h3>
<form action="/reg2/" method="post">
{# 渲染從后端傳來的變量,as_p 是段落#}
{% csrf_token %}
{# {{ form_obj.as_p }}#}
<p>姓名{{ form_obj.user }} <span>{{ errors.obj.user.0 }}</span> </p>
<p>年齡{{ form_obj.age }}<span>{{ errors.obj.age.0 }}</span></p>
<p>郵箱{{ form_obj.email }}<span>{{ errors.obj.email.0 }}</span></p>
<input type="submit">
</form>
</body>
</html>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Python SMTP發(fā)送郵件遇到的一些問題及解決辦法
今天小編就為大家分享一篇關于Python SMTP發(fā)送郵件遇到的一些問題及解決辦法,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10
Python數(shù)據分析與處理(二)——處理中國地區(qū)信息
這篇文章主要介紹了Python數(shù)據分析與處理-處理中國地區(qū)信息,上文介紹了北京高考分數(shù)線統(tǒng)計分析,這篇文章依然圍繞Python數(shù)據分析與處理的相關資料來介紹處理中國地區(qū)信息,需要的朋友可以參考一下2021-12-12
Python使用BeautifulSoup庫解析HTML基本使用教程
這篇文章主要介紹了Python使用BeautifulSoup庫解析HTML基本使用教程,文中主要對其適合于制作爬蟲方面的特性進行了解析,需要的朋友可以參考下2016-03-03
關于AnacondaNavigator?Jupyter?Notebook更換Python內核的問題
因為新安裝的Anaconda?Navigator默認安裝了一個Python,Jupyter?Notebook默認使用的內核就是這個Python,跟我系統(tǒng)安裝好的Python沖突了,下面小編給大家介紹AnacondaNavigator?Jupyter?Notebook更換Python內核的問題,需要的朋友可以參考下2022-02-02
PyCharm更換pip源、模塊安裝以及PyCharm依賴包導入導出功能
這篇文章主要給大家介紹了關于PyCharm更換pip源、模塊安裝以及PyCharm依賴包導入導出功能的相關資料,我們在使用pycharm的時候,pycharm中的虛擬環(huán)境依賴包需要導出成一個文件,需要的朋友可以參考下2023-11-11

