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

作者:只有敬亭山 时间:2023-09-11 17:15:22 

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集合中的对象的必选要素,如果不包含必传要素,就算传入上述数据也是不录入数据库的数据,则可以舍去这些数据。

来源:https://blog.csdn.net/Sponge_bobo_herbert/article/details/81388337

标签:Django,checkbox,复选框,传值
0
投稿

猜你喜欢

  • 详解git reset 加不加 --hard的区别

    2022-04-03 06:45:13
  • Python处理时间戳和时间计算等的脚本分享

    2021-12-20 10:36:50
  • python语音识别的转换方法

    2023-12-06 20:56:57
  • python3.5 + PyQt5 +Eric6 实现的一个计算器代码

    2021-02-27 17:00:28
  • python中map、any、all函数用法分析

    2021-09-02 15:25:45
  • 用js实现放大镜效果

    2023-09-19 18:29:29
  • Sql Server 数据库超时问题的解决方法

    2009-01-13 14:11:00
  • python pycurl验证basic和digest认证的方法

    2022-12-17 23:01:15
  • Python利用PyPDF2快速拆分PDF文档

    2021-11-06 09:39:23
  • 使用Spring.Net框架实现多数据库

    2024-01-14 08:02:22
  • 在Django的View中使用asyncio的方法

    2022-04-10 13:16:41
  • 简化版的vue-router实现思路详解

    2024-05-10 14:17:28
  • 将python字符串转化成长表达式的函数eval实例

    2022-08-25 18:27:23
  • SqlServer 按时间段查询问题

    2024-01-19 02:15:35
  • mysql5.7.23版本安装教程及配置方法

    2024-01-14 15:45:53
  • Python处理mat文件的三种方式小结

    2022-01-21 23:04:30
  • vue后台管理如何配置动态路由菜单

    2024-05-05 09:25:57
  • 09七夕节各大搜索引擎LOGO欣赏

    2009-08-27 15:34:00
  • Django 自定义分页器的实现代码

    2023-06-20 15:21:03
  • python单例模式获取IP代理的方法详解

    2023-11-14 22:22:05
  • asp之家 网络编程 m.aspxhome.com