Django的form组件基本使用——生成标签
1 2 3 4 5 6 7 8 | from django.contrib import admin from django.urls import path from app01 import views urlpatterns = [ path( 'admin/' , admin.site.urls), path( 'test/' ,views.test) #测试form组件的路由 ] |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | from django.shortcuts import render from django import forms #使用form组件需要先导入forms class UserInfo(forms.Form): #创建一个form类 username = forms.CharField( #定义输入框标签username label = '用户名' #定义label,默认为字段名(username) ) password = forms.CharField( label = '密码' , widget = forms.widgets.PasswordInput(attrs = { 'class' : 'c1' }), #widget是forms的一个插件,让密码框密文显示 #attrs={'class': 'c1'} 可以控制标签的属性 ) sex = forms.ChoiceField( #定义选择框,默认生成单选下拉框 choices = (( 1 , '男' ),( 2 , '女' )), widget = forms.widgets.RadioSelect, #通过插件设置成radio单选,可以控制标签的属性 #widget=forms.widgets.Select, #和默认相同(下拉选择) ) hobby = forms.MultipleChoiceField( #定义多选框,默认是下拉框多选 choices = (( 1 , '喝酒' ),( 1 , '抽烟' ),( 3 , '烫头' )), widget = forms.CheckboxSelectMultiple #通过插件设置成checkbox多选框 ) remember_me = forms.ChoiceField( #定义记住密码选项 label = '记住密码' , widget = forms.CheckboxInput #使用插件 ) bday = forms.DateField( #定义一个日期框,但是默认为type=text类型 label = '出版日期' , widget = forms.DateInput(attrs = { 'type' : 'date' }) #设置成日期输入框 ) def test(request): u_obj = UserInfo() #实例化一个form对象 return render(request, 'test.html' ,{ 'u_obj' : u_obj}) #将form对象渲染到前端模板 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 | <!DOCTYPE html> <html lang = "en" > <head> <meta charset = "UTF-8" > <title>test< / title> <style> .c1{ background - color: red; } < / style> < / head> <body> <form action = " " method=" post"> { % csrf_token % } <div> {{ u_obj.username.label }}:{{ u_obj.username }} { # 通过 “.” 调用,生成标签 #} < / div> <div> {{ u_obj.password.label }}:{{ u_obj.password }} < / div> <div> {{ u_obj.sex }} < / div> <div> {{ u_obj.hobby }} < / div> <div> {{ u_obj.remember_me }}{{ u_obj.remember_me.label }} < / div> <div> {{ u_obj.bday }}{{ u_obj.bday.label }} < / div> <div> < input type = "submit" value = "提交" > < / div> < / form> < / body> < / html> |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现