解决Django中checkbox复选框的传值问题


Posted in Python onMarch 31, 2020

Django 中,html 页面通过 form 标签来传递表单数据。

对于复选框信息,即 checkbox 类型,点击 submit 后,数据将提交至 view 中的函数。

我们通过request.POST.get() 函数来获取来自 html 页面的值,但是该函数只能 get 到选中的最后一个值。

因此想要传递选中的多个值,需要用 request.POST.getlist() 函数

该函数返回一个列表,可通过迭代来获取列表中每一项的值。

补充知识:解决checkbox复选框选中传值,不选中不传值的方案

解决checkbox复选框选中传值,不选中不传值的方案

问题描述:

一个form表单中的结构是这样的:

解决Django中checkbox复选框的传值问题

则页面显示结果是:

解决Django中checkbox复选框的传值问题

如上填写数据,经过序列化后的数据是:

[

{"id":"1","infoType":"11","infoName":"名称1","fileIsOpen":"o"},

{"id":"2","infoType":"12","infoName":"名称2","fileIsOpen":"n"}

]

从数据中明显看书fileIsOpen字段的checkbox复选框选中则传值是"o",未被选中则传值是"n",其中这是错误的数据,因为被选中传的值是on,也就是说checkbox复选框选中传值,不选中不传值。那么怎么解决不选中也传值的问题呢?

解决方案:

我们可以设置隐藏域来代替checkbox复选框传递数据,具体的页面修改如下:

解决Django中checkbox复选框的传值问题

checkbox复选框对应的点击事件:

解决Django中checkbox复选框的传值问题

再次输入相同的数据传递的数据是:

[

{"id":"1","infoType":"11","infoName":"名称1","fileIsOpen":"0"},

{"id":"2","infoType":"22","infoName":"名称2","fileIsOpen":"1"}

]

从数据可以这次传递的数据是正确的

上述方案存在的问题

如果页面什么不传递,

解决Django中checkbox复选框的传值问题

则传递的数据是这样的:

[

{"fileIsOpen":"0"},

{"fileIsOpen":"0"}

]

因此后台在接受到数据后需要判断List集合中的对象的必选要素,如果不包含必传要素,就算传入上述数据也是不录入数据库的数据,则可以舍去这些数据。

以上这篇解决Django中checkbox复选框的传值问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
轻松掌握python设计模式之访问者模式
Nov 18 Python
pytorch构建网络模型的4种方法
Apr 13 Python
详解将Django部署到Centos7全攻略
Sep 26 Python
详解python的argpare和click模块小结
Mar 31 Python
Laravel框架表单验证格式化输出的方法
Sep 25 Python
python多进程重复加载的解决方式
Dec 13 Python
PyQt5+Pycharm安装和配置图文教程详解
Mar 24 Python
Python实现AI换脸功能
Apr 10 Python
python报错: 'list' object has no attribute 'shape'的解决
Jul 15 Python
Django通过设置CORS解决跨域问题
Nov 26 Python
python excel多行合并的方法
Dec 09 Python
解决PyCharm无法使用lxml库的问题(图解)
Dec 22 Python
Python文本文件的合并操作方法代码实例
Mar 31 #Python
Python调用接口合并Excel表代码实例
Mar 31 #Python
Python如何批量获取文件夹的大小并保存
Mar 31 #Python
Django使用list对单个或者多个字段求values值实例
Mar 31 #Python
django实现模板中的字符串文字和自动转义
Mar 31 #Python
Python使用graphviz画流程图过程解析
Mar 31 #Python
Django模板之基本的 for 循环 和 List内容的显示方式
Mar 31 #Python
You might like
用PHP实现登陆验证码(类似条行码状)
2006/10/09 PHP
php数组去重的函数代码
2013/02/03 PHP
php将图片保存为不同尺寸图片的图片类实例
2015/03/30 PHP
php封装的数据库函数与用法示例【参考thinkPHP】
2016/11/08 PHP
表单填写时用回车代替TAB的实现方法
2007/10/09 Javascript
JSON 客户端和服务器端的格式转换
2009/08/27 Javascript
Jquery选择子控件"大于号"和" "区别介绍及使用示例
2013/06/25 Javascript
新手学习前端之js模仿淘宝主页网站
2016/10/31 Javascript
Angular 2父子组件之间共享服务通信的实现
2017/07/04 Javascript
node+express+ejs使用模版引擎做的一个示例demo
2017/09/18 Javascript
angularJs在多个控制器中共享服务数据的方法
2018/09/30 Javascript
解决JQuery的ajax函数执行失败alert函数弹框一闪而过问题
2019/04/10 jQuery
mui js控制开关状态、修改switch开关的值方法
2019/09/03 Javascript
vue路由结构可设一层方便动态添加路由操作
2020/08/31 Javascript
Centos5.x下升级python到python2.7版本教程
2015/02/14 Python
详解Python中的日志模块logging
2015/06/19 Python
Python连接PostgreSQL数据库的方法
2016/11/28 Python
python笔记:mysql、redis操作方法
2017/06/28 Python
Python实现屏幕截图的两种方式
2018/02/05 Python
Python实现简单http服务器
2018/04/12 Python
解决PyCharm同目录下导入模块会报错的问题
2018/10/13 Python
解决python线程卡死的问题
2019/02/18 Python
python中的协程深入理解
2019/06/10 Python
Python数据可视化:泊松分布详解
2019/12/07 Python
导入tensorflow:ImportError: libcublas.so.9.0 报错
2020/01/06 Python
使用pytorch 筛选出一定范围的值
2020/06/28 Python
python+appium+yaml移动端自动化测试框架实现详解
2020/11/24 Python
python绘图pyecharts+pandas的使用详解
2020/12/13 Python
深入理解HTML的FormData对象
2016/05/17 HTML / CSS
京东全球售:直邮香港,澳门,台湾,美国,澳大利亚等地区
2017/09/24 全球购物
MYSQL基础面试题
2012/05/13 面试题
积极分子思想汇报
2014/01/04 职场文书
工会经费申请报告
2015/05/15 职场文书
全家福照片寄语怎么写?
2019/04/02 职场文书
Win11如何设置右键单击显示所有选项?Win11右键单击显示所有选项设置教程
2022/04/08 数码科技
MySQL提取JSON字段数据实现查询
2022/04/22 MySQL