解決Django中checkbox復(fù)選框的傳值問題
Django 中,html 頁面通過 form 標(biāo)簽來傳遞表單數(shù)據(jù)。
對于復(fù)選框信息,即 checkbox 類型,點擊 submit 后,數(shù)據(jù)將提交至 view 中的函數(shù)。
我們通過request.POST.get() 函數(shù)來獲取來自 html 頁面的值,但是該函數(shù)只能 get 到選中的最后一個值。
因此想要傳遞選中的多個值,需要用 request.POST.getlist() 函數(shù)
該函數(shù)返回一個列表,可通過迭代來獲取列表中每一項的值。
補充知識:解決checkbox復(fù)選框選中傳值,不選中不傳值的方案
解決checkbox復(fù)選框選中傳值,不選中不傳值的方案
問題描述:
一個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',其中這是錯誤的數(shù)據(jù),因為被選中傳的值是on,也就是說checkbox復(fù)選框選中傳值,不選中不傳值。那么怎么解決不選中也傳值的問題呢?
解決方案:
我們可以設(shè)置隱藏域來代替checkbox復(fù)選框傳遞數(shù)據(jù),具體的頁面修改如下:

checkbox復(fù)選框?qū)?yīng)的點擊事件:

再次輸入相同的數(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'}]
因此后臺在接受到數(shù)據(jù)后需要判斷List集合中的對象的必選要素,如果不包含必傳要素,就算傳入上述數(shù)據(jù)也是不錄入數(shù)據(jù)庫的數(shù)據(jù),則可以舍去這些數(shù)據(jù)。
以上這篇解決Django中checkbox復(fù)選框的傳值問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. ASP基礎(chǔ)知識Command對象講解2. JavaScript實現(xiàn)留言板實戰(zhàn)案例3. 使用Blazor框架實現(xiàn)在前端瀏覽器中導(dǎo)入和導(dǎo)出Excel4. Python使用Selenium自動進(jìn)行百度搜索的實現(xiàn)5. 如何從Python的cmd中獲得.py文件參數(shù)6. python中文本字符處理的簡單方法記錄7. JS中6個對象數(shù)組去重的方法8. PHP laravel實現(xiàn)導(dǎo)出PDF功能9. Python-openpyxl表格讀取寫入的案例詳解10. vscode運行php報錯php?not?found解決辦法

網(wǎng)公網(wǎng)安備