html的form表单
django中,前端如果要提交一些数据到views里面去,需要用到 html里面的form表单。
例如:
# form2/urls.py
from django.contrib import admin from django.urls import path,re_path from django.conf.urls import include from . import views urlpatterns = [ re_path(r'^home$', views.home), re_path(r'^login$', views.login), ]
# views.py
from django.shortcuts import render,HttpResponse def login(request): return render(request, 'form2/login.html')
# login.html
<form action="/form2/home" method="post"> #向这个页面发送post请求,action配置目标地址
<p>用户名:<input type="text" name="username"></p> #name表示key,value等于input输入的内容
<input type="submit" value="提交">
</form>
第二种方法: 使用url_name
login.html <form action="{% url 'homepage' %}" method="post">
app.urls
urlpatterns = [
re_path(r'^home$', views.home,name='homepage'), #url命名
re_path(r'^login$', views.login),
]
第三种方法:使用namespace命名空间 (作用:当有多个app.urls时,如果存在重复的name,容易引起混乱,这时候需要引入namespace)
login.html
action="{% url 'app_name:url_name' param %}" #param参数,没有就不写
<form action="{% url 'app_form2:homepage' %}" method="post">
根urls
path('form2/', include('form2.urls',namespace='aaaa')), #namespace必须有值,值好像可随便取~
app.urls
app_name = 'app_form2' #django2.0之后必须写此项,否则会报错
urlpatterns = [
re_path(r'^home$', views.home, name='homepage'), #url_name
# form2/views.py
from django.shortcuts import render,HttpResponse def login(request): return render(request, 'form2/login.html') def home(request): username = request.POST.get('username') or 'lily' #前端form表单传过来的username数据,如果为空则默认为'lily' return render(request, 'form2/homepage.html', {"username":username}) #将username传给homepage.html
# homepage.html
<body>
welcome, {{username}}! # views传过来的username变量
</body>
访问 http://127.0.0.1:8000/form2/login
提交之后,login页面会跳转到/form2/home页面
Django的form表单
主要作用是1,生成html标签,2,表单验证。
# 新建forms.py ,定义表单字段类型
from django import forms class Person_Info(forms.Form): name = forms.CharField(max_length=4) # 字符串类型,最长不超过4个字符 birthday = forms.DateField() #日期类型 email = forms.EmailField(required=False) # required=False表示可以为空,默认是True,不能为空 phone = forms.IntegerField() #数值类型
# views.py
from django.shortcuts import render,HttpResponse from .forms import Person_Info #导入form表单 def person(request): person_obj = Person_Info() # 创建了这个对象 return render(request,'form2/info.html',{'obj':person_obj}) #然后把对象传给html
info.html
<form action="" method="post">
{% csrf_token %} # django自带的csrf验证,不加提交时会报错
{{ obj }} # views传的对象, 可以自动创建html标签
<div>姓名:{{ obj.name }}</div> # 也可以取对象中的某一个字段 <input type="submit" value="提交"> </form>
csrf_token如果不加上,提交表单会报错
或者在settings里面注释掉'django.middleware.csrf.CsrfViewMiddleware', 这行也可以。
访问 http://127.0.0.1:8000/form2/info可以看到生成的表单。体现了django的form的第一个作用,自动生成html标签,如下:
填入数据的时候,如果数据不合法,就会有提示。
这样在后端就可以验证,如果字段合法,就获取数据操作,如果不合法,就返回错误信息。
验证用户输入
views.py
from django.shortcuts import render from .forms import Person_Info def person(request): form_obj = Person_Info() if request.method == 'POST': #获取用户输入 print("request.POST:", request.POST) form_obj = Person_Info(request.POST) #将post过来的数据当做参数传给Person_Info这个form表单,将name,birthday,email等封装到form_obj,判断输入是否合法 print("form is valid:", form_obj.is_valid()) # 通过is_valid()方法判断表单数据是否合法 return render(request, 'form2/info.html', {"obj": form_obj})
这里我输入一个不合法的birthday,可以看到:
增加一个判断,如果填写的表单正确,返回表单数据,如果不合法,返回错误信息。
from django.shortcuts import render,HttpResponse from .forms import Person_Info def person(request): if request.method == 'POST': form_obj = Person_Info(request.POST) if form_obj.is_valid(): print("form is valid ^_^ ", form_obj.cleaned_data) # 返回表单数据,是字典形式 else: print("form is invalid!!!T_T ", form_obj.errors) # .errors 获取错误信息 return render(request, 'form2/info.html', {'obj': form_obj}) else: form_obj = Person_Info() return render(request, 'form2/info.html', {'obj': form_obj})
分别测试: