Django里的ModelForm组件

ModelForm组件

  • 自动生成HTML标签 + 自动读取关联数据
  • 表单验证 + 错误提示
  • 数据库进行:新建,修改

步骤如下:

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

# 创建一个类
class AssetModelForm(forms.ModelForm):
    class Meta:
        model = models.AssetSet 
        #fields = ['name', 'price', 'category', 'depart']  # 可以这么写
		fields = "__all__"

  • 视图函数
# 在 views.py 里

def asset_add(request):
    """
    # 获取所有类型
    cat_list = models.AssetSet.category_choices
    dp_list = models.Department.objects.all()

    form = AssetForm()
    """
    
    cat_list = models.AssetSet.category_choices
    dp_list = models.Department.objects.all()
    form = AssetModelForm()

    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>

效果如下:
请添加图片描述


如果要想添加在数据库没有的field到前端页面,可以这么操作

# 在 views.py 文件里

class AssetModelForm(forms.ModelForm):
    newField = forms.CharField()  # 添加新的field
    class Meta:
        model = models.AssetSet 
        #fields = ['name', 'price', 'category', 'depart', 'newField']
        fields = "__all__"

效果如下:
添加了红色方框里的输入框
请添加图片描述


要想在 ModelForm 里对某一些 Field 添加 css 样式,可以这么操作

# 在 views.py 文件里

class AssetModelForm(forms.ModelForm):
    newField = forms.CharField()
    class Meta:
        model = models.AssetSet 
        fields = ['name', 'price', 'category', 'depart']
        #fields = "__all__"

        """
        # 单一的给某个field添加样式
        widgets = {
            'category': forms.Select(attrs={'style': "width: 300px;"})
        }
        """

    # 给所有的 field 提供样式
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        for name, field in self.fields.items():
            if name == "price":
                continue
            field.widget.attrs['style'] = "width: 100px"

这样效果就呈现在下面
请添加图片描述


点个赞呗~

相关推荐

  1. Django ModelForm用法详解 —— Python

    2024-06-07 08:32:05       28 阅读
  2. Django 解决自定义中间问题

    2024-06-07 08:32:05       28 阅读
  3. Django——forms

    2024-06-07 08:32:05       41 阅读
  4. Django forms

    2024-06-07 08:32:05       35 阅读
  5. Django Form

    2024-06-07 08:32:05       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-07 08:32:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-07 08:32:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-07 08:32:05       82 阅读
  4. Python语言-面向对象

    2024-06-07 08:32:05       91 阅读

热门阅读

  1. Quartz 中的错过机制MisFire

    2024-06-07 08:32:05       34 阅读
  2. C++指针指向字符串首地址的例子

    2024-06-07 08:32:05       23 阅读
  3. 【Linux】grep命令详解

    2024-06-07 08:32:05       30 阅读
  4. C语言printf( ) 函数有哪些参数?

    2024-06-07 08:32:05       25 阅读
  5. 嵌入式笔试面试刷题(day17)

    2024-06-07 08:32:05       18 阅读