• 技术文章 >web前端 >js教程

    ajax怎样传递数组到后台

    php中世界最好的语言php中世界最好的语言2018-03-31 15:08:24原创8548
    这次给大家带来ajax怎样传递数组到后台,ajax传递数组到后台的注意事项有哪些,下面就是实战案例,一起来看一下。

    前言

    我们在使用ajax异步的提交多选框得到需要操作的对象的id,这时我们可以把每一个id做出一个对象,之后放到一个数组中,再使用JSON.stringify()对这个数组进行json的格式化;在后台中再inputStream中解析出我们的json字符串,之后只用:

    new JSONArray()得到json数组,循环解析我们想要的属性:

    var countsCheckBox = $("input[type='checkbox']:checked"); 
     var booksid = []; 
     for(var i=0;i<countsCheckBox.length;i++){ 
     //使用[]取得元素是是一个domElement元素,取值需要使用.value, 
     //如果使用countsCheckBox.eq(i) 则是一个Obkject元素,就可以使用val()取值 
     //alert(countsCheckBox[i].value); 
     mysendbook_id = {}; 
     mysendbook_id['book_id'] = countsCheckBox[i].value; 
     booksid[i] = mysendbook_id; 
     } 
     //alert(booksid); 
      var confirmdel= confirm('确认要删除吗?'); 
      if(confirmdel){ 
      //开始请求删除 
       $.ajax({ 
         url:'selectdelbooks', 
         data:JSON.stringify(booksid), 
         type:'post', 
         success:function(res){ 
          alert("删除成功"); 
         location.replace("/TheDemo/books/pageBooksShow"); 
         } 
         }); 
      }

    上面的js中我们把每一个选中的id放到一个mysendbook_id的“book_id”的属性中,再把这个对象放到booksid的数组中;到发送异步请求时使用

    JSON.stringify(bookid)格式化这个booksid数组,得到一个json的数组。

    再看后台我们怎么接收:

    一个是做一个类里面有一个list,这个list装的是只有一个属性为bookid的类,再使用注解@RequestBody加到这个形参上。但是这样比较麻烦;

    还有一种是从输入流里面获取数据,使用IOUtils.toString 把inputStream转为字符串,再使用new JSONArray(mybooksid);得到这个json数组

    从而得到每一个json中的book_id的属性值

    <span style="font-family:SimSun;font-size: 10.5pt;"> </span><span style="font-family:KaiTi_GB2312;font-size:14px;"> @RequestMapping("selectdelbooks") 
     public String selectdelbooks(HttpServletRequest request) throws Exception { 
      ServletInputStream inputStream = request.getInputStream(); 
      String mybooksid = IOUtils.toString(inputStream); 
      JSONArray jsonarr = new JSONArray(mybooksid); 
      List<String> book_id =new ArrayList<String>(); 
      for (int i=0;i<jsonarr.length();i++){ 
       book_id.add(((JSONObject)jsonarr.get(i)).getString("book_id")); 
      }...</span>

    这样我们得到一个list,里面有我们选中的id值。

    数据库中信息:

    页面的多选:

    后台得到的选择的book的id:

    相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    推荐阅读:

    如何实现AJAX的分页效果

    怎样用Ajax提交表单并接收其中的json数据

    实现列表无限加载与二级下拉菜单选项的Ajax(附代码)

    以上就是ajax怎样传递数组到后台的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:ajax 后台 数组
    上一篇:在Ajax里怎么传递特殊字符数据 下一篇:AJAX在不刷新的情况下检测输入的用户名
    20期PHP线上班

    相关文章推荐

    精选22门好课,价值3725元,开通VIP免费学习!• JavaScript中switch的四种写法示例• 一文快速详解ES6~ES12的全部特性!• Angular如何进行视图封装?聊聊三种封装模式• 万字图解JavaScript笔记总结• 如何搞懂虚拟 DOM?看看这篇文章吧!
    1/1

    PHP中文网