zoukankan      html  css  js  c++  java
  • django--ModelForm

    modelform就是把model和form组合起来

    首先需要导入ModelForm

    class StudentList(ModelForm):
      class Meta:
        model = models.Student #对应的Model中的类
        fields = "__all__"   #字段,如果是__all__,就是表示列出所有的字段
        exclude = None     #排除的字段
        labels = None      #提示信息
        help_texts = None    #帮助提示信息
        widgets = None     #自定义插件
        error_messages = None  #自定义错误信息
    #error_messages用法:
        error_messages = {
          'name':{'required':"用户名不能为空",},
          'age':{'required':"年龄不能为空",},
        }
    #widgets用法,比如把输入用户名的input框给为Textarea
    #首先得导入模块
        from django.forms import widgets as wid #因为重名,所以起个别名
        widgets = {
          "name":wid.Textarea(attrs={"class":"c1"}) #还可以自定义属性
        }
    #labels,自定义在前端显示的名字
        labels= {
          "name":"用户名"
        }

    然后在url对应的视图函数中实例化这个类,把这个对象传给前端

    def student(request):
     
      if request.method == 'GET':
        student_list = StudentList()
        return render(request,'student.html',{'student_list':student_list})

    然后前端只需要     {{ student_list.as_p }}   一下,所有的字段就都出来了,可以用as_p显示全部,也可以通过for循环这student_list,拿到的是一个个input框,现在我们就不用as_p,手动把这些input框搞出来,as_p拿到的页面太丑。

    首先 for循环这个student_list,拿到student对象,直接在前端打印这个student,是个input框
    student.label  ,拿到数据库中每个字段的verbose_name ,如果没有设置这个属性,拿到的默认就是字段名

    还可以通过student.errors.0 拿到错误信息

    有了这些,我们就可以通过bootstrap,自己拼出来想要的样式了

    <body>
      <div class="container" >
        <h1>student</h1>
        <form method="POST" novalidate>
          {% csrf_token %}
    {#      {{ student_list.as_p }}#}
          {% for student in student_list %}
            <div class="form-group col-md-6">
             {# 拿到数据字段的verbose_name,没有就默认显示字段名 #}
              <label class="col-md-3 control-label">{{ student.label }}</label>
              <div class="col-md-9" style="position: relative;">{{ student }}</div>
            </div>
          {% endfor %}
          <div class="col-md-2 col-md-offset-10">
            <input type="submit" value="提交" class="btn-primary">
          </div>
        </form>
      </div>
    </body>

    编辑数据

    如果不用ModelForm,编辑的时候得显示之前的数据吧,还得挨个取一遍值,如果ModelForm,只需要加一个instance=obj(obj是要修改的数据库的一条数据的对象)就可以得到同样的效果

    保存的时候要注意,一定要注意有这个对象(instance=obj),否则不知道更新哪一个数据

    from django.shortcuts import render,HttpResponse,redirect
    from django.forms import ModelForm
    # Create your views here.
    from app01 import models
    def test(request):
      # model_form = models.Student
      model_form = models.Student.objects.all()
      return render(request,'test.html',{'model_form':model_form})
     
    class StudentList(ModelForm):
      class Meta:
        model = models.Student #对应的Model中的类
        fields = "__all__"   #字段,如果是__all__,就是表示列出所有的字段
        exclude = None     #排除的字段
        labels = None      #提示信息
        help_texts = None    #帮助提示信息
        widgets = None     #自定义插件
        error_messages = None  #自定义错误信息
    #error_messages用法:
        error_messages = {
          'name':{'required':"用户名不能为空",},
          'age':{'required':"年龄不能为空",},
        }
    #widgets用法,比如把输入用户名的input框给为Textarea
    #首先得导入模块
        from django.forms import widgets as wid #因为重名,所以起个别名
        widgets = {
          "name":wid.Textarea
        }
    #labels,自定义在前端显示的名字
        labels= {
          "name":"用户名"
        }
    def student(request):
      if request.method == 'GET':
        student_list = StudentList()
        return render(request,'student.html',{'student_list':student_list})
      else:
        student_list = StudentList(request.POST)
        if student_list.is_valid():
          student_list.save()
        return render(request,'student.html',{'student_list':student_list})
    def student_edit(request,pk):
      obj = models.Student.objects.filter(pk=pk).first()
      if not obj:
        return redirect('test')
      if request.method == "GET":
        student_list = StudentList(instance=obj)
        return render(request,'student_edit.html',{'student_list':student_list})
      else:
        student_list = StudentList(request.POST,instance=obj)
        if student_list.is_valid():
          student_list.save()
        return render(request,'student_edit.html',{'student_list':student_list})

    原文https://www.cnblogs.com/zhang-can/p/7712790.html 感谢

  • 相关阅读:
    WebSocket
    Jedis工具类
    电脑突然没有声音了 右下角红叉叉,由于其配置信息(注册表中的)不完整或已损坏,Windows 无法启动这个硬件设备。 (代码19)
    java.lang.IllegalArgumentException: jdbcUrl is required with driverClassName.
    WCF中的数据契约(Continued)
    WCF中的服务契约
    搭建基于MOSS的团队解决方案01——Microsoft Office SharePoint 2007 Server快速入门(Continued)
    Silverlight 的发展之路
    Windows Workflow Foundation实验01——Windows Workflow Foundation快速入门(练习四)
    使用.NET平台工具操作Live Framework
  • 原文地址:https://www.cnblogs.com/duGD/p/11295907.html
Copyright © 2011-2022 走看看