Django里的Form组件

Form组件提供

  • 自动生成HTML标签和半自动读取关联数据 (“半自动”是指还得需要自己手写输入数据进来)
  • 表单验证和错误提示

要想创建并使用该组件,操作步骤如下:

  • 在 views.py 里创建类
# 在 views.py 文件里

from django import forms

class AssetForm(forms.Form):
    name = forms.CharField(required=True, widget=forms.TextInput)
    price = forms.CharField(required=True, widget=forms.TextInput)
    category = forms.ChoiceField(required=True, widget=forms.Select, choices=models.AssetSet.category_choices)

# 调用了在 models.py 文件里的类

class AssetSet(models.Model):
    # 只适用于固定的选择
    category_choices = ((1, '文具类'), (2, '3C类'), (3, '房产类'))
    category = models.SmallIntegerField(verbose_name="资产类型", choices=category_choices)

    # 外键 depart_id
    depart = models.ForeignKey(verbose_name="所属部门", to="Department", to_field="id", on_delete=models.CASCADE)

class Department(models.Model):
    title = models.CharField(verbose_name="标题", max_length=16)

  • 在 views.py 文件里创建一个函数
def asset_add(request):
    # 获取所有类型
    cat_list = models.AssetSet.category_choices
    dp_list = models.Department.objects.all()

    form = AssetForm()

    return render(request, 'asset_add.html', {'cat_list': cat_list, 'dp_list': dp_list, 'form': form})

  • 在 html 页面里调用组件内容
<form>
	<!-- 第一种写法 -->
    <!-- {{ form.name }}
    {{ form.price }} -->

    {% for field in form %}
        {{ field }}
    {% endfor %}
</form>

显示的页面结果:
请添加图片描述


点个赞呗~

相关推荐

  1. Django——forms

    2024-06-07 07:42:06       20 阅读
  2. Django forms

    2024-06-07 07:42:06       17 阅读
  3. Django Form

    2024-06-07 07:42:06       7 阅读
  4. Django高级之-forms

    2024-06-07 07:42:06       17 阅读
  5. Web框架开发-Django-form

    2024-06-07 07:42:06       19 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-07 07:42:06       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-07 07:42:06       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-07 07:42:06       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-07 07:42:06       18 阅读

热门阅读

  1. iOS13之后获取状态栏高度的方法

    2024-06-07 07:42:06       9 阅读
  2. db2实例的环境变量

    2024-06-07 07:42:06       6 阅读
  3. Ansible——command 模块

    2024-06-07 07:42:06       11 阅读
  4. 简述浏览器和 Node.js 中的事件循环 ?

    2024-06-07 07:42:06       11 阅读
  5. 统计每天某个时间范围内得 数据状态

    2024-06-07 07:42:06       8 阅读
  6. 45-4 护网溯源 - 溯源相关思路

    2024-06-07 07:42:06       7 阅读
  7. http和websocket区别

    2024-06-07 07:42:06       8 阅读
  8. 前端面试题日常练-day56 【面试题】

    2024-06-07 07:42:06       9 阅读
  9. PostgreSQL中有没有类似Oracle的dba_objects系统视图

    2024-06-07 07:42:06       7 阅读
  10. UDP声音传输:播放的声音有很大的噪音

    2024-06-07 07:42:06       10 阅读
  11. MySQL DBA项目实战系列培训课程【MySQL 8.4最新版】

    2024-06-07 07:42:06       10 阅读
  12. 使用docker安装mysql详细教程

    2024-06-07 07:42:06       10 阅读
  13. 数组知识点

    2024-06-07 07:42:06       8 阅读