1. 程式人生 > 實用技巧 >Django與from元件

Django與from元件

froms元件介紹

1 註冊功能,登入功能,前端需要校驗(欄位長度,郵箱是否合法。。。)
2 前端校驗可以沒有,後端校驗是必須的,使用傳統方式  if判斷寫的很多
3 藉助於forms元件,可以快速實現欄位的校驗
    from django.forms import Form

froms校驗欄位功能

### 1 寫一個類,類裡寫要校驗的欄位
class MyForm(forms.Form):
    # 校驗這個欄位,最大長度是32,最小長度是3
    name = forms.CharField(required=False, max_length=32, min_length=3
,label='使用者名稱') email = forms.EmailField(label='郵箱') age=forms.IntegerField(max_value=200,min_value=0,label='年齡') ### 2 檢視函式中使用 def register(request): # 資料可以是從前端傳過來的,也可以是自己後臺的資料 # 我現在有以下資料 data={'name':'lqz','email':'[email protected]','age':900} # data={'email':'[email protected]
','age':100} # data={'age':100} # 校驗資料是否合法 # 例項化得到form物件,把要校驗的資料傳入 form=myforms.MyForm(data) # 校驗資料:form.is_valid() 返回布林型別 if form.is_valid(): print('校驗通過') # 校驗通過的資料 print(form.cleaned_data) # 不一定是上面傳入的資料 else: print(form.cleaned_data) print(
'校驗失敗') # 哪個欄位失敗了?失敗的原因是什麼 print(form.errors) print(type(form.errors)) from django.forms.utils import ErrorDict #### 重寫了__str__ print(form.errors.as_json())#列印看得懂的資料 print(form.errors.as_data()) # form.errors.as_ul() # 是為了渲染模板 return HttpResponse('ok')

forms渲染模板功能

## 檢視函式
def register(request):
    if request.method=='GET':
        form=myforms.MyForm()
        return render(request,'register.html',{'form':form})
    elif request.method=='POST':
        # 資料校驗
        form=myforms.MyForm(request.POST)
        if form.is_valid():
            print('校驗通過,存資料庫')
        else:
            print(form.errors.as_data())
            print('校驗失敗,返回錯誤')
        return HttpResponse('ok')
    

## 模板
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <hr> <h1>手動建立模板</h1> <form action="" method="post"> <p>使用者名稱:<input type="text" name="name"></p> <p>郵箱:<input type="text" name="email"></p> <p>年齡:<input type="text" name="age"></p> <p><input type="submit" value="提交"></p> </form> <hr> <h1>半自動渲染模板1</h1> <form action="" method="post"> <p>使用者名稱:{{ form.name }}</p> <p>郵箱:{{ form.email }}</p> <p>年齡:{{ form.age }}</p> <p><input type="submit" value="提交"></p> </form> <h1>半自動渲染模板2(用的最多)</h1> <form action="" method="post"> <p>{{ form.name.label }}--{{ form.name }}</p> <p>{{ form.email.label }}---{{ form.email }}</p> <p>{{ form.age.label }}---{{ form.age }}</p> <p><input type="submit" value="提交"></p> </form> <h1>半自動渲染模板3(用的最多)</h1> <form action="" method="post"> {% for foo in form %} <p>{{ foo.label }} :{{ foo }}</p> {% endfor %} <p><input type="submit" value="提交"></p> </form> <h1>全自動(瞭解)</h1> <form action="" method="post"> {# {{ form.as_ul }}#} {{ form.as_p }} {# <table>#} {# {{ form.as_table }}#} {# </table>#} <p><input type="submit" value="提交"></p> </form> </body> </html>