解決Django中checkbox復(fù)選框的傳值問題
Django 中,html 頁面通過 form 標(biāo)簽來傳遞表單數(shù)據(jù)。
對(duì)于復(fù)選框信息,即 checkbox 類型,點(diǎn)擊 submit 后,數(shù)據(jù)將提交至 view 中的函數(shù)。
我們通過request.POST.get() 函數(shù)來獲取來自 html 頁面的值,但是該函數(shù)只能 get 到選中的最后一個(gè)值。
因此想要傳遞選中的多個(gè)值,需要用 request.POST.getlist() 函數(shù)
該函數(shù)返回一個(gè)列表,可通過迭代來獲取列表中每一項(xiàng)的值。
補(bǔ)充知識(shí):解決checkbox復(fù)選框選中傳值,不選中不傳值的方案
解決checkbox復(fù)選框選中傳值,不選中不傳值的方案
問題描述:
一個(gè)form表單中的結(jié)構(gòu)是這樣的:
則頁面顯示結(jié)果是:
如上填寫數(shù)據(jù),經(jīng)過序列化后的數(shù)據(jù)是:
[{'id':'1','infoType':'11','infoName':'名稱1','fileIsOpen':'o'},{'id':'2','infoType':'12','infoName':'名稱2','fileIsOpen':'n'}]
從數(shù)據(jù)中明顯看書fileIsOpen字段的checkbox復(fù)選框選中則傳值是'o',未被選中則傳值是'n',其中這是錯(cuò)誤的數(shù)據(jù),因?yàn)楸贿x中傳的值是on,也就是說checkbox復(fù)選框選中傳值,不選中不傳值。那么怎么解決不選中也傳值的問題呢?
解決方案:
我們可以設(shè)置隱藏域來代替checkbox復(fù)選框傳遞數(shù)據(jù),具體的頁面修改如下:
checkbox復(fù)選框?qū)?yīng)的點(diǎn)擊事件:
再次輸入相同的數(shù)據(jù)傳遞的數(shù)據(jù)是:
[{'id':'1','infoType':'11','infoName':'名稱1','fileIsOpen':'0'},{'id':'2','infoType':'22','infoName':'名稱2','fileIsOpen':'1'}]
從數(shù)據(jù)可以這次傳遞的數(shù)據(jù)是正確的
上述方案存在的問題
如果頁面什么不傳遞,
則傳遞的數(shù)據(jù)是這樣的:
[{'fileIsOpen':'0'},{'fileIsOpen':'0'}]
因此后臺(tái)在接受到數(shù)據(jù)后需要判斷List集合中的對(duì)象的必選要素,如果不包含必傳要素,就算傳入上述數(shù)據(jù)也是不錄入數(shù)據(jù)庫的數(shù)據(jù),則可以舍去這些數(shù)據(jù)。
以上這篇解決Django中checkbox復(fù)選框的傳值問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Python PyQt5-圖形界面的美化操作2. python 編寫輸出到csv的操作3. 利用原生JS實(shí)現(xiàn)歡樂水果機(jī)小游戲4. js的一些潛在規(guī)則使用分析5. JAMon(Java Application Monitor)備忘記6. PHP swoole的process模塊創(chuàng)建和使用子進(jìn)程操作示例7. IntelliJ IDEA 常用設(shè)置(配置)吐血整理(首次安裝必需)8. php中加密解密DES類的簡單使用方法示例9. 詳解python第三方庫的安裝、PyInstaller庫、random庫10. 手把手教你用python發(fā)送短消息(基于阿里云平臺(tái))
