Django ModelForm用法详解

Django ModelForm是一种自动生成表单的工具,它是以模型为基础,在模型类上定义的表单。在使用Django ModelForm时,我们只需要指定模型类作为表单数据的基础,就可以自动地生成表单。下面是Django ModelForm用法的完整攻略。

创建ModelForm

首先,我们需要定义一个ModelForm。在创建ModelForm时,需要通过指定Meta类来定义ModelForm的一些元信息,如所使用的model、fields等,如下所示:

from django import forms
from myapp.models import MyModel

class MyModelForm(forms.ModelForm):
    class Meta:
        model = MyModel
        fields = ['field1', 'field2', 'field3']

在上面的代码中,我们创建了一个名为MyModelForm的ModelForm,并定义了它的Meta类。该类指定了所使用的模型为MyModel,并明确了要使用的字段。

使用ModelForm渲染表单

在视图中,我们可以通过以下方式使用ModelForm来渲染一个表单:

def my_view(request):
    # 如果通过 POST 方法提交表单数据
    if request.method == 'POST':
        form = MyModelForm(request.POST)
        if form.is_valid():
            # 表单合法,则处理提交的数据
            form.save()
            return HttpResponseRedirect('/thanks/')

    # 如果不是 POST 方法提交,则创建一个空白的表单
    else:
        form = MyModelForm()

    return render(request, 'my_template.html', {'form': form})

在上面的代码中,我们尝试从请求中获取表单数据,如果发现表单的数据是有效的,那么就对其进行处理,否则就显示错误信息。如果请求类型不是POST,则直接生成一个空白的表单。

在模板中渲染表单

在上面的视图中,我们在调用render函数时向模板中传入了表单:{'form': form}。我们可以在模板中通过简单地调用表单的as_p()、as_table()或as_ul()方法来将表单渲染为HTML,如下所示:

<form method="POST">
    {% csrf_token %}
    {{ form.as_p }}
    <button type="submit">Save</button>
</form>

在上面的HTML代码中,我们使用了form.as_p方法,将表单渲染成一个段落列表(即

标签)。

自定义表单的元素

除了自动生成表单外,Django ModelForm还允许我们向表单中添加自定义元素。我们可以在ModelForm的init()方法中添加自定义的字段,如下所示:

from django import forms
from myapp.models import MyModel

class MyModelForm(forms.ModelForm):
    my_field = forms.CharField(max_length=100, required=False)

    class Meta:
        model = MyModel
        fields = ['field1', 'field2', 'field3']

    def __init__(self, *args, **kwargs):
        super(MyModelForm, self).__init__(*args, **kwargs)
        self.fields['my_field'].label = "My field label"

在上面的代码中,我们向表单添加了一个自定义的字段my_field,它是一个CharField类型。在模板中,我们可以像处理其他字段那样,通过{{ form.my_field }}来使用自定义的字段。

自定义表单的验证

Django ModelForm还允许我们自定义表单的验证。我们可以通过覆盖ModelForm的clean()方法来实现自定义验证,如下所示:

from django import forms
from myapp.models import MyModel

class MyModelForm(forms.ModelForm):
    class Meta:
        model = MyModel
        fields = ['field1', 'field2', 'field3']

    def clean(self):
        cleaned_data = super().clean()
        field1 = cleaned_data.get("field1")
        field2 = cleaned_data.get("field2")
        if field1 and field2:
            if field1 > field2:
                raise forms.ValidationError(
                    "Field1 cannot be greater than Field2"
                )

在上面的代码中,我们重写了ModelForm的clean()方法,并在其中定义了自定义验证逻辑,用于验证是否满足特定的条件。在这个例子中,我们验证了field1是否大于field2。

定义自定义的表单格式

最后,我们可以用widget属性自定义Django ModelForm的实例,来对表单进行格式化和样式的修改。例如我们可以添加一个自定义的style,如下所示:

from django import forms
from myapp.models import MyModel

class MyModelForm(forms.ModelForm):
    class Meta:
        model = MyModel
        fields = ['field1', 'field2', 'field3']
        widgets = {
            'field1': forms.TextInput(attrs={'class': 'my-class'}),    
            'field2': forms.TextInput(attrs={
                'class': 'my-class',
                'style': 'color: red;'    
            }),    
        }

在上面的代码中,我们使用widget属性添加了自定义的样式,其中field1使用系统class "my-class"来定义样式;而field2则同时使用系统class和额外的自定义style,以达到自己所期望的效果。

总结

到这里,我们已经简单了解了Django ModelForm的用法,它可以自动生成表单,并允许我们对表单进行自定义,以满足我们的需求。但是需要注意,对于较复杂的表单,可能需要使用Django Forms或者自定义表单。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django ModelForm用法详解 - Python技术站

(0)
上一篇 2023年3月12日
下一篇 2023年3月12日

相关文章

  • django 执行 python manage.py makemigrations 报错

    RuntimeError: Model class app_anme.models.xxx doesn’t declare an explicit app_label and isn’t in an application in INSTALLED_APPS.  将app加入settings的INSTALLED_APPS 中

    Django 2023年4月11日
    00
  • 【Django】QuerySet的分页和排序

    数据查询分页功能和排序功能大家都很熟悉,本文以一个小例子介绍一下Django后台实现 id依次从6到1 [ { “detail”: “this is test”, “CreateTime”: “2016-05-22 00:06:36”, “ModifyTime”: “2016-05-22 00:06:36”, “IsDelete”: “False”, “Ty…

    Django 2023年4月13日
    00
  • Python – Django – 命名空间模式

    新建一个项目 app02 在 app02/ 下创建 urls.py: from django.conf.urls import url from app02 import views urlpatterns = [ url(r’^blog/’, views.test, name=”blog”), ] app01/urls.py: from django.co…

    Django 2023年4月10日
    00
  • Django调试工具django-debug-toolbar安装使用教程

    在网站开发中难免要调试页面,而使用django开发站点时,可以使用django-debug-toolbar来进行调试,安装这个插件很有用,我一开始是为了查看某个页面中所有的context变量值,当然你还可以看到HTTp头、模板、缓存等各种信息,总之很全面也很好用。 以前比较习惯在windows中安装pycharm开发,项目部署在虚拟机中,在本地浏览器中查看效…

    Django 2023年4月11日
    00
  • python27+django1.9添加api

    我们进入Python的交互 shell 并使用Django提供的API。要进入Python shell,使用python manage.py shell 使用这个而不是简单的输入”python”,是因为 manage.py 会帮你创建项目的环境。“创建项目环境”包括两件事: 把polls添加到sys.path里。为了灵活性,Django中的模块通过加点的路径…

    Django 2023年4月10日
    00
  • [django]django 3种返回json方法

    django 3种返回json方法 1.手动组装字典返回 from django.http import JsonResponse, HttpResponse from django.shortcuts import render from app01.models import Book # Create your views here. def get_…

    Django 2023年4月10日
    00
  • [django]模板中自定义变量&django模板中的变量

    django自定义模板变量 context_processors.py def mysetings(request): return { ‘NAME’: ‘maotai’ } settings.py TEMPLATES = [ { ‘BACKEND’: ‘django.template.backends.django.DjangoTemplates’, ‘D…

    Django 2023年4月10日
    00
  • Django聚合查询、分组查询、F与Q查询

    表查询 基于django settings源码实现自己的项目 配置文件的可插拔式设计 dir() importlib 反射 ​ 单表查询 只要是queryset对象 就可以无限制的点击queryset对象的方法 13条 1.all() # 查所有 2.filter() # 根据条件过滤 多个条件之间是and关系 3.get() # 直接获取数据对象 查询条件…

    Django 2023年4月11日
    00
合作推广
合作推广
分享本页
返回顶部