Django里的ModelForm组件

ModelForm组件

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

步骤如下:

  • 创建类
python 复制代码
# 在 views.py 文件里

# 创建一个类
class AssetModelForm(forms.ModelForm):
    class Meta:
        model = models.AssetSet 
        #fields = ['name', 'price', 'category', 'depart']  # 可以这么写
		fields = "__all__"
  • 视图函数
python 复制代码
# 在 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 页面里得用循环来显示从数据库获取的数据
html 复制代码
<form>
    <!-- {{ form.name }}
    {{ form.price }} -->

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

效果如下:


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

python 复制代码
# 在 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 样式,可以这么操作

python 复制代码
# 在 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"

这样效果就呈现在下面


点个赞呗~

相关推荐
qq_2975746711 小时前
【实战教程】SpringBoot 实现多文件批量下载并打包为 ZIP 压缩包
java·spring boot·后端
好家伙VCC12 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
前端玖耀里13 小时前
如何使用python的boto库和SES发送电子邮件?
python
serve the people13 小时前
python环境搭建 (十二) pydantic和pydantic-settings类型验证与解析
java·网络·python
小天源13 小时前
Error 1053 Error 1067 服务“启动后立即停止” Java / Python 程序无法后台运行 windows nssm注册器下载与报错处理
开发语言·windows·python·nssm·error 1053·error 1067
喵手13 小时前
Python爬虫实战:HTTP缓存系统深度实战 — ETag、Last-Modified与requests-cache完全指南(附SQLite持久化存储)!
爬虫·python·爬虫实战·http缓存·etag·零基础python爬虫教学·requests-cache
喵手13 小时前
Python爬虫实战:容器化与定时调度实战 - Docker + Cron + 日志轮转 + 失败重试完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·容器化·零基础python爬虫教学·csv导出·定时调度
2601_9491465314 小时前
Python语音通知接口接入教程:开发者快速集成AI语音API的脚本实现
人工智能·python·语音识别
寻梦csdn14 小时前
pycharm+miniconda兼容问题
ide·python·pycharm·conda
Java面试题总结15 小时前
基于 Java 的 PDF 文本水印实现方案(iText7 示例)
java·python·pdf