jq 完成复选框的全选和全不选,并组装成数组发送到后台

jQuery 代码实现,HTML dom节点对应js的id 即可

复制代码
<script>    
    $(function() {
        //复选框全选和全不选
        $("#selectAll").click(function() {
            $(":checkbox[name='item']").prop("checked", this.checked); // this指代的你当前选择的这个元素的JS对象
        })
    })
    
    //将checkbox获取选中的值转成数组
    function selectCheckbox(){
        var obj=$("input[name='item']");  
        arr = [];
        for(k in obj){
            if(obj[k].checked)
               arr.push(obj[k].value);
        }
        return arr;
    }
    
    //保存数据
    function saveData(){
        var selectArray = selectCheckbox();
        $.ajax({
            url:"dealxxxx.jsp",
            data:{selectArray:selectArray},
            dataType:"json",
            traditional:true,
            success:function(res){
                if(res=="000"){
                    alert("OK");
                    location.reload();
                }else{
                    alert("error");
                    location.reload();
                }
            },
            error:function(){
                alert("error");
                location.reload();
            }
            
        })
    }
</script>
复制代码

后台接收数组对象值
dealxxxx.jsp 使用jsp内置的request对象来获取
String[] selectArray = request.getParameterValues("selectArray");

 

总结ajax 发送请求后台处理成功但返回error 的问题

  1. 返回数据类型不是JSON
  2. 网络中断
  3. 后台响应中断
  4. 是否为跨域请求
  5. jquery版本过高导致数组对象传输时每个值都当作一个数组的问题,解决办法:traditional:true  

 

posted @   渊渟岳  阅读(224)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示