• django表单的使用说明


    表单:
    HTML中的表单:
    单纯从前端的html来说,表单是用来提交数据给服务器的,不管后台的服务器用的是Django还是PHP语言还是其他语言。只要把input标签放在form标签中,然后再添加一个提交按钮,那么以后点击提交按钮,就可以将input标签中对应的值提交给服务器了。

    Django中的表单:
    Django中的表单丰富了传统的HTML语言中的表单。在Django中的表单,主要做以下两件事:

    渲染表单模板。
    表单验证数据是否合法。
    Django中表单使用流程:
    在讲解Django表单的具体每部分的细节之前。我们首先先来看下整体的使用流程。这里以一个做一个留言板为例。首先我们在后台服务器定义一个表单类,继承自django.forms.Form。示例代码如下:

    forms.py

    class MessageBoardForm(forms.Form):
    title = forms.CharField(max_length=3,label=‘标题’,min_length=2,error_messages={“min_length”:‘标题字符段不符合要求!’})
    content = forms.CharField(widget=forms.Textarea,label=‘内容’)
    email = forms.EmailField(label=‘邮箱’)
    reply = forms.BooleanField(required=False,label=‘回复’)
    然后在视图中,根据是GET还是POST请求来做相应的操作。如果是GET请求,那么返回一个空的表单,如果是POST请求,那么将提交上来的数据进行校验。示例代码如下:

    views.py

    class IndexView(View):
    def get(self,request):
    form = MessageBoardForm()
    return render(request,‘index.html’,{‘form’:form})

    def post(self,request):
        form = MessageBoardForm(request.POST)
        if form.is_valid():
            title = form.cleaned_data.get('title')
            content = form.cleaned_data.get('content')
            email = form.cleaned_data.get('email')
            reply = form.cleaned_data.get('reply')
            return HttpResponse('success')
        else:
            print(form.errors)
            return HttpResponse('fail')
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在使用GET请求的时候,我们传了一个form给模板,那么以后模板就可以使用form来生成一个表单的html代码。在使用POST请求的时候,我们根据前端上传上来的数据,构建一个新的表单,这个表单是用来验证数据是否合法的,如果数据都验证通过了,那么我们可以通过cleaned_data来获取相应的数据。在模板中渲染表单的HTML代码如下:

        
            
            
        
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    我们在最外面给了一个form标签,然后在里面使用了table标签来进行美化,在使用form对象渲染的时候,使用的是table的方式,当然还可以使用ul的方式(as_ul),也可以使用p标签的方式(as_p),并且在后面我们还加上了一个提交按钮。这样就可以生成一个表单了
  • 相关阅读:
    文心一言 VS 讯飞星火 VS chatgpt (136)-- 算法导论11.3 2题
    Jeecgboot 字典值自动转化:DictAspect类方法改造,支持IPage、List、Object、Map类自动转化,附有源码
    6.DesignForPlacement\ExportHighlightedList
    如何合并为pdf文件?合并为pdf文件的方法
    【C语言】经典编程题
    vite +vue3-ts架构,我要打包的时候打包成压缩包zip文件
    南辕北辙
    java 基于 SpringMVC+Mybaties+ Html5 + Vue 前后端分离 房地产管理系统 的 设计与实现
    Vue路由介绍及使用
    【生命周期】
  • 原文地址:https://blog.csdn.net/qq_17584941/article/details/125887237