溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django ModelForm組件的使用方法

發布時間:2020-10-28 20:52:40 來源:億速云 閱讀:246 作者:Leah 欄目:開發技術

Django 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":"用戶名"
    }

如果想增加一個字段,就在class Meta 之前寫這個字段。然后在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 拿到錯誤信息,還有student.field,是拿到每個字段,如果這個字段是多對多字段,還能stuent.field.queryset,拿到所有關聯的字段,還能stuent.field.queryset.model,拿到所有關聯的字段的類。有了這些,我們就可以通過bootstrap,自己拼出來想要的樣式了

比如:

<body>
  <div class="container" >
    <h2>student</h2>
    <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" >{{ student }}</div>
        </div>
      {% endfor %}

      <div class="col-md-2 col-md-offset-10">
        <input type="submit" value="提交" class="btn-primary">
      </div>
    </form>
  </div>
</body>

現在還缺一個input框的form-control樣式,可以考慮在后臺的widget里面添加。

比如這樣:

from django.forms import widgets as wid #因為重名,所以起個別名
    widgets = {
      "name":wid.TextInput(attrs={'class':'form-control'}),
      "age":wid.NumberInput(attrs={'class':'form-control'}),
      "email":wid.EmailInput(attrs={'class':'form-control'})
    }

當然也可以在js中,找到所有的input框,加上這個樣式,也行。

保存數據的時候,不用挨個取數據了,只需要save一下。

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 redirect(request,'student_list.html',{'student_list':student_list})

編輯數據:

如果不用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})

使用ModelForm編輯數據

對于驗證規則,很多瀏覽器都比較智能,會自動幫我們做一些驗證,可以在form表單上加 novalidate 屬性就可以不讓瀏覽器為我們做驗證

ModelForm還支持所有form的功能,比如鉤子,所以我們就可以通過鉤子來自定義驗證規則

寫法和forms的寫法一樣:

class AuthorForm(forms.ModelForm):
  class Meta:
    model = Author
    fields = ('name', 'title')

  def clean_name(self):
    if ...
       return self.clean_data['name']
    else:
       raise ValidationError(‘sdgsadga')
    ...

關于Django ModelForm組件的使用方法問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女