一周学会Django5 Python Web开发 - Django5 Form表单定义与使用

锋哥原创的Python Web开发 Django5视频教程:

2024版 Django5 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili2024版 Django5 Python web开发 视频教程(无废话版) 玩命更新中~共计51条视频,包括:2024版 Django5 Python web开发 视频教程(无废话版) 玩命更新中~、第2讲 Django5安装、第3讲 Django5创建项目(用命令方式)等,UP主更多精彩视频,请关注UP账号。icon-default.png?t=N7T8https://www.bilibili.com/video/BV14Z421z78C/首先forms.py里定义下BookInfoForm类

class BookInfoForm(Form):
    """
    图书表单
    """
    bookName = forms.CharField(max_length=20, label="图书名称")
    price = forms.FloatField(label="图书价格")
    publishDate = forms.DateField(label="出版日期")
    # 获取图书类别列表
    bookTypeList = BookTypeInfo.objects.values()
    # 图书类别以下拉框形式显示,下拉框选项id是图书类别Id,下拉框选项文本是图书类别名称
    choices = [(v['id'], v['bookTypeName']) for v, v in enumerate(bookTypeList)]
    bookType_id = forms.ChoiceField(required=False, choices=choices, label="图书类别")

views.py下新建preAdd2方法

def preAdd2(request):
    """
    预处理,添加操作 使用form表单
    :param request:
    :return:
    """
    form = BookInfoForm()
    context_value = {"title": "图书添加", "form": form}
    return render(request, 'book/add2.html', context_value)

urls.py加下映射:

path('book/preAdd2', helloWorld.views.preAdd2),

book/list.html加一个新的添加链接:

<a href="/book/preAdd2">添加(使用form)</a><br/><br/>

我们测试下哈,http://127.0.0.1:8000/book/list,点下 添加(使用form)

输入表单信息,点击提交,测试成功。

表单Form的常用属性和方法如下:

  • data:默认值为None,以字典形式表示,字典的键为表单字段,代表将数据绑定到对应的表单字段。

  • auto_id:默认值为id_%s,以字符串格式化表示,若设置HTML元素控件的id属性,比如表单字段job,则元素控件id属性为id_job,%s 代表表单字段名称。

  • prefix:默认值为None,以字符串表示,设置表单的控件属性name和id的属性值,如果一个网页里使用多个相同的表单,那么设置该属性可以区分每个表单。

  • initial:默认值为None,以字典形式表示,在表单的实例化过程中设置初始化值。

  • label_suffix:若参数值为None,则默认为冒号,以表单字段job为例,其HTML控件含有label标签(<label for="id_job">职位:</label> ),其中 label标签里的冒号由参数label_suffix设置。field_order:默认值为None,则以表单字段定义的先后顺序进行排列,若要自定义排序,则将每个表单字段按先后顺序放置在列表里,并把列表作为该参数的值。

  • use_required_attribute:默认值为None(或为True ),为表单字段所对应的 HTML控件设置required属性,该控件为必填项,数据不能为空,若设为False,则HTML控件为可填项。errors():验证表单的数据是否存在异常,若存在异常,则获取异常信息,异常信息可设为字典或JSON格式。

  • is_valid():验证表单数据是否存在异常,若存在,则返回False,否则返回True。

  • as_table():将表单字段以HTML的<table>标签生成网页表单。

  • as_ul():将表单字段以HTML的<ul>标签生成网页表单。

  • as _p():将表单字段以HTML的<p>标签生成网页表单。

  • has_changed():对比用于提交的表单数据与表单初始化数据是否发生变化。

表单定义字段如如下类型:

  • CharField:文本框,参数max_length 和min_length分别设置文本长度。

  • IntegerField:数值框,参数max_value设置最大值,min_value设置最小值。

  • FloatField:数值框,继承IntegerField,验证数据是否为浮点数。

  • DecimalField:数值框,继承IntegerField,验证数值是否设有小数点,参数max_digits设置最大位数,参数decimal_places设置小数点最大位数。

  • DateField:文本框,继承BaseTemporalField,具有验证日期格式的功能,参数input_formats设置日期格式。

  • TimeField:文本框,继承BaseTemporalField,验证数据是否为datetime.time或特定时间格式的字符串。

  • DateTimeField:文本框,继承 BaseTemporalField,验证数据是否为datetime.datetime ,datetime.date或特定日期时间格式的字符串。

  • DurationField:文本框,验证数据是否为一个有效的时间段。

  • RegexField:文本框,继承CharField,验证数据是否与某个正则表达式匹配,参数regex设置正则表达式。

  • EmailField:文本框,继承CharField,验证数据是否为合法的邮箱地址。

  • FileField:文件上传框,参数max_length设置上传文件名的最大长度,参数allow_empty_file设置是否允许文件内容为空。

  • ImageField:文件上传控件,继承FileField,验证文件是否为Pillow库可识别的图像格式。FilePathField:文件选择控件,在特定的目录选择文件,参数 path是必需参数,参数值为目录的绝对路径;参数recursive、match、 allow_files和allow_folders为可选参数。 URLField:文本框,继承CharField,验证数据是否为有效的路由地址。

  • BooleanField:复选框,设有选项True和 False,如果字段带有required=True,复选框就默认为True。

  • NullBooleanField:复选框,继承BooleanField,设有3个选项,分别为None、True和 False。ChoiceField:下拉框,参数choices 以元组形式表示,用于设置下拉框的选项列表。

  • TypedChoiceField:下拉框,继承 ChoiceField,参数coerce 代表强制转换数据类型,参数empty_value表示空值,默认为空字符串。

  • MultipleChoiceField:下拉框,继承ChoiceField,验证数据是否在下拉框的选项列表。

  • TypedMultipleChoiceField:下拉框,继承MultipleChoiceField,验证数据是否在下拉框的选项列表,并且可强制转换数据类型,参数coerce代表强制转换数据类型,参数 empty_value表示空值,默认为空字符串。

  • ComboField:文本框,为表单字段设置验证功能,比如字段类型为CharField,为该字段添加EmailField,使字段具有邮箱验证功能。

  • MultiValueField:文本框,将多个表单字段合并成一个新的字段。

  • SplitDateTimeField:文本框,继承MultiValueField,验证数据是否为datetime.datetime或特定日期时间格式的字符串。

  • GenericIPAddressField:文本框,继承CharField,验证数据是否为有效的IP地址。

  • SlugField:文本框,继承CharField,验证数据是否只包括字母、数字、下画线及连字符。

  • UUIDField:文本框,继承CharField,验证数据是否为UUID格式。

每个表单有一些常用属性如下:

  • required:输入的数据是否为空,默认值为True。

  • widget:设置HTML控件的样式。

  • label:用于生成label标签的网页内容。initial:设置表单字段的初始值。

  • help_text:设置帮助提示信息。

  • error_messages:设置错误信息,以字典形式表示,比如{'required": '不能为空', 'invalid': '格式错误}。

  • show_hidden_initial:参数值为True/False,是否在当前控件后面再加一个隐藏的且具有默认值的控件( 可用于检验两次输入的值是否一致)。

  • validators:自定义数据验证规则。以列表格式表示,列表元素为函数名。localize:参数值为True/False,设置本地化,不同时区自动显示当地时间。disabled:参数值为True/False,HTML控件是否可以编辑。

  • label_suffix:设置label 的后缀内容。

参数widget是一个forms.widgets对象,有4大类小部件:文本框类型,下拉框(复选框)类型,文件上传类型和复合框类型;

文本框类型:

  • TextInput,对应CharField字段,文本框内容设置为文本格式

  • NumberInput,对应IntegerField字段,文本框内容只允许输入数值

  • Emaillnput,对应 EmailField字段,验证输入值是否为邮箱地址格式

  • URLInput,对应URLField字段,验证输入值是否为路由地址格式

  • PasswordInput,对应CharField字段,输入值以“*”显示

  • HiddenInput,对应CharField字段,隐藏文本框,不显示在网页上

  • DateInput,对应DateField字段,验证输入值是否为日期格式

  • DateTimeInput,对应DateTimeField字段,验证输入值是否为日期时间格式

  • TimeInput,对应TimeField字段,验证输入值是否为时间格式

  • Textarea,对应CharField字段,将文本框设为Textarea格式

下拉框(复选框)类型:

  • CheckboxInput,对应 BooleanField字段,设置复选框,选项为True和 False

  • Select,对应 ChoiceField字段,设置下拉框

  • NullBooleanSelect,对应NullBooleanField,设置复选框,选项为None、True和 False

  • SelectMultiple,对应ChoiceField字段,与Select类似,允许选择多个值

  • RadioSelect,对应ChoiceField字段,将数据列表设置为单选按钮

  • CheckboxSelectMultiple,对应ChoiceField字段,与SelectMultiple类似,设置为复选框列表

文件上传类型:

  • FileInput,对应 FileField 或 ImageField字段

  • ClearableFileInput,对应 FileField 或ImageField字段,但多了复选框,允许清除上传的文件和图像

复合框类型:

  • MultipleHiddenInput,隐藏一个或多个HTML的控件

  • SplitDateTimeWidget,组合使用Datelnput和 Timelnput

  • SplitHiddenDateTimeWidget,与SplitDateTimeWidget类似,但将控件隐藏,不显示在网页上

  • SelectDateWidget,组合使用3个Select,分别生成年、月、日的下拉框

我们优化下前面表单实例,加一个字段验证,以及样式;

forms.py修改下BookInfoForm类:

class BookInfoForm(Form):
    """
    图书表单
    """
    bookName = forms.CharField(
        max_length=20,
        label="图书名称",
        required=True,
        widget=widgets.TextInput(attrs={"placeholder": "请输入用户名", "class": "inputCls"})
    )
    price = forms.FloatField(label="图书价格")
    publishDate = forms.DateField(label="出版日期")
    # 获取图书类别列表
    bookTypeList = BookTypeInfo.objects.values()
    # 图书类别以下拉框形式显示,下拉框选项id是图书类别Id,下拉框选项文本是图书类别名称
    choices = [(v['id'], v['bookTypeName']) for v, v in enumerate(bookTypeList)]
    bookType_id = forms.ChoiceField(required=False, choices=choices, label="图书类别")

add2.html加个样式:

    <style>
        .inputCls {
            width: 200px;
        }
    </style>

运行测试:

  • 28
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值