摘要:原文地址關(guān)于在同個頁面多個表單提交的問題實際上是項目中遇到的個小問題。實際關(guān)于在個頁面提交多個表單的問題實際上問題不是很多只要解決了渲染和提交時處理的問題實際這個問題就迎刃而解了。
原文地址:
http://52sox.com/how-to-handl...
關(guān)于在同1個頁面多個表單提交的問題,實際上是項目中遇到的1個小問題。關(guān)于這個問題,主要有2個需要解決的問題:
多個表單的渲染問題
多個表單提交時外鍵的處理問題
下面我們分別進行說明。
當(dāng)時在建模的時候使用了類似如下的方式:
from django.db import models class Store(models.Model): name = models.CharField("名稱", max_length=20) first = models.FloatField("首重") additional = models.FloatField("次重") img = models.ImageField("圖片", upload_to="store/1") class Depot(models.Model): s_name = models.ForeignKey(Store, verbose_name="倉庫") src = models.CharField("始發(fā)地", max_length=20) dest = models.CharField("目的地", max_length=20) days = models.PositiveSmallIntegerField("需要的天數(shù)") class Address(models.Model): s_name = models.ForeignKey(Store, verbose_name="倉庫") country = models.CharField("國家", max_length=20) state = models.CharField("省份", max_length=10) city = models.CharField("城市", max_length=10) description = models.TextField("描述", blank=True)
在這里,1個倉庫的數(shù)據(jù)主要由3個表組成,分別為它的一些基礎(chǔ)信息,可以配送的范圍、天數(shù)及其他一些附加信息組成。然后其頁面如下所示:
多表單渲染而公司的需求就是我們要在商戶端上讓客戶在創(chuàng)建倉庫時填寫上述的內(nèi)容,由于我比較懶,而公司給出的時間也不是很充裕,于是直接使用ModelForm來實現(xiàn),而不需要一一的創(chuàng)建表單了。換句話說,我們要將多個模型表在同1個頁面中渲染出來,對于這樣的問題,主要有4種解決的方案:
在1個form組件中使用多個模型表單類
使用django提供的modelform_factory來解決
使用第3方插件django-betterforms或django-multipleformwizard這樣的插件
使用元類,然后繼承BaseForm進行表單的重寫。
這里我們使用第1種解決方案來實現(xiàn)多個表單渲染的問題。
這里我們在forms模塊下新建3個模型表單類:
from django.forms import ModelForm from models import Store, Address, Depot class StoreForm(ModelForm): class Meta: model = Store fields = "__all__" class AddressForm(ModelForm): class Meta: model = Address exclude = ["s_name"] class DepotForm(ModelForm): class Meta: model = Depot exclude = ["s_name"]
然后在視圖中引入這3個表單:
from django.shortcuts import render_to_response, HttpResponseRedirect from django.template import RequestContext from forms import StoreForm, AddressForm, DepotForm def store_add(req): if req.method == "POST": ... else: sf = StoreForm() af = AddressForm() df = DepotForm() return render_to_response("store_add.html", { "sf": sf, "af": af, "df": df, }, context_instance=RequestContext(req))
默認(rèn)情況下,我們先將對應(yīng)的表單渲染出來先。在這里我們往模板中輸出了多個變量,然后在模板中手動進行如下的處理:
在這里,我們在1個表單中輸出多個表單,其頁面如下所示:
可以看到其效果與后臺的頁面相差不是很大,只是沒有對應(yīng)的樣式而已。
多表單提交外鍵處理接著我們需要處理多個表單提交時的處理問題。
def store_add(req): if req.method == "POST": sf = StoreForm(req.POST, req.FILES) af = AddressForm(req.POST) df = DepotForm(req.POST) if sf.is_valid() and af.is_valid() and df.is_valid(): sf.save() df.save() af.save() return HttpResponseRedirect("store") ...
在這里我們直接對這3個表單進行保存,結(jié)果出現(xiàn)了這樣1個錯誤。
NOT NULL constraint failed: app_depot.s_name_id
由于我們使用了1個外鍵進行了約束,而使用上述的方式會導(dǎo)致數(shù)據(jù)表中的s_name_id的字段數(shù)值為NULL,從而導(dǎo)致了錯誤。而上述的方式時直接就提交給數(shù)據(jù)庫了,導(dǎo)致后面的外鍵無法被滿足。為了解決這個問題,我們采用延遲提交給數(shù)據(jù)庫的方式:
def store_add(req): if req.method == "POST": ... if sf.is_valid() and af.is_valid() and df.is_valid(): form = sf.save(commit=False) sf.save() dform = df.save(commit=False) dform.s_name = form dform.save() aform = af.save(commit=False) aform.s_name = form aform.save() return HttpResponseRedirect("store") else: ...
在這里,我們先讓第1張表先不提交,將其保存為1個變量form中。而第2個張表也先不提交,我們將其實例的s_name修改為之前的第1張表返回的結(jié)果,然后再進行保存。這樣我們就實現(xiàn)了多張表的依賴導(dǎo)致的問題了。最后我們使用重定向的方式將成功添加后的頁面跳轉(zhuǎn)到該商戶的倉庫列表中。
其跳轉(zhuǎn)后的頁面如下所示:
這樣我們就解決了在1個頁面提交多個表單的問題。
實際關(guān)于Django在1個頁面提交多個表單的問題,實際上問題不是很多,只要解決了渲染和提交時處理的問題,實際這個問題就迎刃而解了。重要的是如何拆分問題和解決問題的思路。
參考文章:
http://stackoverflow.com/ques...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/38223.html
摘要:每一篇文章的標(biāo)簽可能都不一樣,并且還可能擁有多個標(biāo)簽,這是與欄目功能不同的。列表中顯示標(biāo)簽雖然保存標(biāo)簽的功能已經(jīng)實現(xiàn)了,還得把它顯示出來才行。更多的用法請閱讀官方文檔總結(jié)本章學(xué)習(xí)了使用來完成標(biāo)簽功能。 標(biāo)簽是作者從文章中提取的核心詞匯,其他用戶可以通過標(biāo)簽快速了解文章的關(guān)注點。每一篇文章的標(biāo)簽可能都不一樣,并且還可能擁有多個標(biāo)簽,這是與欄目功能不同的。 好在標(biāo)簽功能也有優(yōu)秀的三方庫:D...
摘要:本教程內(nèi)容已過時,更新版教程請訪問博客開發(fā)入門教程。我們的評論表單放在中,評論成功后返回到原始提交頁面。學(xué)習(xí)小組簡介學(xué)習(xí)小組是一個促進新手互相學(xué)習(xí)互相幫助的組織。 本教程內(nèi)容已過時,更新版教程請訪問: django 博客開發(fā)入門教程。 通過前四周的時間我們開發(fā)了一個簡單的個人 Blog,前幾期教程地址: 第一周:Django 學(xué)習(xí)小組:博客開發(fā)實戰(zhàn)第一周教程 —— 編寫博客的 Mode...
摘要:本教程內(nèi)容已過時,更新版教程請訪問博客開發(fā)入門教程。我們的評論表單放在中,評論成功后返回到原始提交頁面。學(xué)習(xí)小組簡介學(xué)習(xí)小組是一個促進新手互相學(xué)習(xí)互相幫助的組織。 本教程內(nèi)容已過時,更新版教程請訪問: django 博客開發(fā)入門教程。 通過前四周的時間我們開發(fā)了一個簡單的個人 Blog,前幾期教程地址: 第一周:Django 學(xué)習(xí)小組:博客開發(fā)實戰(zhàn)第一周教程 —— 編寫博客的 Mode...
摘要:競賽平臺項目中期總結(jié)軟件謝運帷我們小組的選題是大學(xué)生競賽平臺項目,經(jīng)過我們需求分析,原型設(shè)計等等步驟,我們終于要開始著手實現(xiàn)這一個龐大的競賽平臺項目。 Cesar競賽平臺項目中期總結(jié) 軟件51 謝運帷 2015013185 我們小組的選題是大學(xué)生競賽平臺項目,經(jīng)過我們需求分析,原型設(shè)計等等步驟,我們終于要開始著手實現(xiàn)這一個龐大的競賽平臺項目。我們使用Django+mysql處理后端邏輯...
閱讀 3520·2023-04-25 15:52
閱讀 590·2021-11-19 09:40
閱讀 2617·2021-09-26 09:47
閱讀 1035·2021-09-22 15:17
閱讀 3560·2021-08-13 13:25
閱讀 2241·2019-08-30 15:56
閱讀 3474·2019-08-30 13:56
閱讀 2113·2019-08-30 11:27