from django.contrib import admin
from django.urls import path
from app01 import views urlpatterns = [
path('admin/', admin.site.urls),
path('login/',views.login)
]
from django.db import models class Userinfo(models.Model):
username = models.CharField(max_length=20)
password = models.CharField(max_length=60)
from django.shortcuts import render,HttpResponse
from django import forms #匯入forms元件
from app01.models import Userinfo #匯入要使用的模型 #之前自己定義表單類的欄位,現在繼承ModelForm後,可以直接將模型生成一個form表單
class UserLoginForm(forms.ModelForm): #定義一個類,要繼承 ModelForm password = forms.CharField( #如果模型中的欄位不夠用,也可以自己定義欄位,自己加的欄位在生成表單的時候預設會放在最後
widget=forms.widgets.PasswordInput(render_value=True)
) class Meta:
model = Userinfo #指定要使用的模型
fields = '__all__' #要顯示哪些欄位, '__all__'表示全部顯示, 也可以顯示一部分:fields = ['欄位1','欄位2','欄位3', ...]
exclude = ['password'] #不顯示的欄位 def login(request):
if request.method == 'POST':
userloginform = UserLoginForm(request.POST)
userloginform.save() #將提交的form表單資料對應的欄位資料儲存到資料庫中
return HttpResponse('儲存成功')
else:
userloginform = UserLoginForm()
return render(request,'login.html',{'userloginform': userloginform})
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Login</title>
<style></style>
</head>
<body>
<form action="" method="post" novalidate>
{% csrf_token %} <div>
{{ userloginform.as_p }} {# userloginform.as_p: 將所有的元素渲染在<p>標籤中顯示 , 同理的還有{{ form.as_table }}和{{ form.as_ul }} #}
</div> <div>
<input type="submit" value="提交">
</div>
</form>
</body>
</html>
2、使用ModelForm實踐操作