表单输出选项
{{ form.as_table }}:以表格形式加载表单元素
{{ form.as_p }}:以段落形式加载表单元素
{{ form.as_ul }:以列表形式加载表单元素
表单相关的属性
{{ field.label }}:字段对应的<lable>标签的文字,例如“发件人”。
{{ field.label_tag }}:字段对应的<lable>标签。
{{ field.id_for_label }}:字段的“id”属性值。
{{ field.value }}:字段的值,例如标题的内容。
{{ field.html_name }}:字段对应的HTML标签“name”属性的值。
{{ field.help_text }}:字段的帮助文本。
{{ field.errors }}:包含任何字段验证错误的全部信息,可以通过“{% for error in field.errors %}”的方式遍历。
{{ field.is_hidden }}:字段是否隐藏字段,获取到的是布尔值。
{{ field.field }}:字段对象,可以通过它访问字段的属性,例如“{{ field.field.max_length }}”,“{{ field.field.required}}”。
补充知识:django ModelForm中添加非必填项(not require)字段方法
在工作中经常会遇到一个form中会有部分字段不需要一定有值。
如一个form中,想要address这个字段是一个非必填项。相关代码如下
class My_Form(ModelForm): class Meta: model = My_Class fields = ('first_name', 'last_name' , 'address')
第一种解决办法:
class My_Form(ModelForm): address = forms.CharField(required=False) class Meta: model = My_Class fields = ('first_name', 'last_name' , 'address')
第二种解决办法:
class My_Form(forms.ModelForm): class Meta: model = My_Class fields = ('first_name', 'last_name' , 'address') def __init__(self, *args, **kwargs): super(My_Form, self).__init__(*args, **kwargs) self.fields['address'].required = False
以上这篇django form和field具体方法和属性说明就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。