原文链接:https://blog.csdn.net/qq_37936542/article/details/79277495

一:ajax传递List<String>类型的数据

js代码:

  1. //声明list
  2. var _list = [];
  3. //放入string对象
  4. for (var i = 0; i < 3; i++) {
  5. _list[i]="tom";
  6. }
  7. $.ajax({
  8. url : '/ajax/test',
  9. data : "list="+_list,
  10. type : "POST",
  11. success : function(data) {
  12. alert(data);
  13. }
  14. });

java代码:

  1. @RequestMapping(value="test",method=RequestMethod.POST)
  2. @ResponseBody
  3. public String ajaxList(@RequestParam("list")List<String> strList){
  4. for (String str : strList) {
  5. System.out.println(str);
  6. }
  7. return "OK";
  8. }

二:ajax传递List<Obj>类型的数据

后台需要用到json解析工具,我选得是jackson

导入jackson依赖:

  1. <dependency>
  2. <groupId>com.fasterxml.jackson.core</groupId>
  3. <artifactId>jackson-databind</artifactId>
  4. <version>2.7.3</version>
  5. </dependency>

js代码:

  1. //声明list
  2. var _list = [];
  3. //创建两个user对象
  4. var a= {};
  5. a.name="tom";
  6. a.age=23;
  7. a.city="上海";
  8. var b = {};
  9. b.name="jack";
  10. b.age=25;
  11. a.city="安徽";
  12. //将user放入_list
  13. _list.push(a);
  14. _list.push(b);
  15. $.ajax({
  16. url : '/ajax/test1',
  17. data : "list="+JSON.stringify(_list),
  18. type : "POST",
  19. success : function(data) {
  20. alert(data);
  21. }
  22. });

java代码:

  1. @RequestMapping(value="test",method=RequestMethod.POST)
  2. @ResponseBody
  3. public String ajaxList(@RequestParam("list")String userList) throws Exception{
  4. //jackson对象
  5. ObjectMapper mapper = new ObjectMapper();
  6. //使用jackson将json转为List<User>
  7. JavaType jt = mapper.getTypeFactory().constructParametricType(ArrayList.class, User.class);
  8. List<User> list =  (List<User>)mapper.readValue(userList, jt);
  9. return "OK";
  10. }

三:当ajax传递任何复杂参数时,后台可以直接从流中来读取数据进行解析

js代码:

  1. //声明list
  2. var _list = [];
  3. //创建两个user对象
  4. var a= {};
  5. a.name="tom";
  6. a.age=23;
  7. a.city="上海";
  8. var b = {};
  9. b.name="jack";
  10. b.age=25;
  11. a.city="安徽";
  12. //将user放入_list
  13. _list.push(a);
  14. _list.push(b);
  15. $.ajax({
  16. url : '/querz/test',
  17. data : JSON.stringify(_list),//这里需要json化
  18. type : "POST",
  19. success : function(data) {
  20. alert(data);
  21. }
  22. });

java代码:

  1. @RequestMapping(value="test",method=RequestMethod.POST)
  2. @ResponseBody
  3. public String ajaxList(HttpServletRequest request) throws Exception{
  4. //从流中读取数据
  5. BufferedReader br = request.getReader();
  6. String str = "";
  7. StringBuffer sb = new StringBuffer();
  8. while((str = br.readLine()) != null){
  9. sb.append(str);
  10. }
  11. ObjectMapper mapper = new ObjectMapper();
  12. //使用jackson解析数据
  13. JavaType jt = mapper.getTypeFactory().constructParametricType(ArrayList.class, User.class);
  14. List<User> list =  (List<User>)mapper.readValue(sb.toString(), jt);
  15. System.out.println(list);
  16. return "OK";
  17. }

文末福利:

福利一:前端,Java,产品经理,微信小程序,Python等10G资源合集大放送:https://www.jianshu.com/p/e8197d4d9880

福利二:微信小程序入门与实战全套详细视频教程

【领取方法】

关注 【编程微刊】微信公众号:

回复【小程序demo】一键领取130个微信小程序源码demo资源。

回复【领取资源】一键领取前端,Java,产品经理,微信小程序,Python等资源合集10G资源大放送。



90后前端妹子,爱编程,爱运营,爱折腾。
坚持总结工作中遇到的技术问题,坚持记录工作中所所思所见,欢迎大家一起探讨交流。

ajax传递list集合的更多相关文章

  1. SpringMVC,SpringBoot使用ajax传递对象集合/数组到后台

    假设有一个bean名叫TestPOJO. 1.使用ajax从前台传递一个对象数组/集合到后台. 前台ajax写法: var testPOJO=new Array(); //这里组装testPOJO数组 ...

  2. 原生态ajax 传递json参数到服务器端

    案例说明:通过ajax将用户名和密码以json形式传递给服务器端,然后服务器端接受数据,进行处理返回json数据到前端 首先,在客户端,通过JavaScript脚本将页面表单数据封装成JSON格式.L ...

  3. 怎么通过js获取上传的图片信息(临时保存路径,名称,大小)然后通过ajax传递给后端?

    今天在论坛上看到这样一个问题,有必要编辑搜集下. 问题描述:怎么通过js获取上传的图片信息(临时保存路径,名称,大小)然后通过ajax传递给后端 题主用jquery接收 <input name= ...

  4. 后台接受ajax传递值的实例代码

    后台接受ajax传递值的实例代码: 使用ajax可以实现无刷新数据交互,下面是一段后台代码接收ajax传递值的实例代码供需要的朋友参考,希望能够带来帮助. ajax代码如下: $(function ( ...

  5. ASP.NET jquery ajax传递参数

    第一种:GET传递 前台 ajax   GET 传递 :即在请求的地址后面加上参数,URL地址长度有显示,安全性低 后台接收:Request.QueryString[“参数名字”]! 例如: func ...

  6. servlet向ajax传递list数据类型,ajax向servlet传递array数据类型

    因工作需要, 1,后台向前台传递一个list 2,前台向后台传递类似于list的结构,但是因为javascript不支持list类型,所以只能使用二维数组代替 后台运行后的截图:           ...

  7. jquery ajax传递数组给php

    写成:var data = {'item[]':item}; $.post(url,data,function(return_data) 写成item:item会导致数据缺失. 更多:http://w ...

  8. 小笔记(一):ajax传递数组及将ajax返回数据赋值

    当使用ajax传递数据时,有可能传递多个数据,这是使用以下方法传递数据就会显得数据过多且混杂 $.ajax({ type:'post', url:url, data:{data:data,conten ...

  9. jQuery ajax传递特殊字符串问题

    当你用ajax传递值到服务器端,如果值中包含特殊字符串如+,&等,在服务器端获取的结果可能就会出现差异,因为这些字符有其它用途,如“+”表示连接符,在转义后你获取到的就是空格.可以看看这些特殊 ...

随机推荐

  1. BZOJ3529: [Sdoi2014]数表(莫比乌斯反演,离线)

    Description 有一张 n×m 的数表,其第 i 行第 j 列(1 <= i <= n, 1 <= j <= m)的数值为 能同时整除 i 和 j 的所有自然数之和.给 ...

  2. bzoj3307雨天的尾巴(权值线段树合并/DSU on tree)

    题目大意: 一颗树,想要在树链上添加同一物品,问最后每个点上哪个物品最多. 解题思路: 1.线段树合并 假如说物品数量少到可以暴力添加,且树点极少,我们怎么做. 首先在一个树节点上标记出哪些物品有多少 ...

  3. NuGet 使用及dll管理

    NuGet学习笔记(1)——初识NuGet及快速安装使用 作者: 懒惰的肥兔  来源: 博客园  发布时间: 2012-05-20 21:33  阅读: 53168 次  推荐: 33   原文链接  ...

  4. 语音识别系统:有免费实用的"语音到文字"的软件么?

    自从看了<李开复自传>,就对"语音识别系统"产生了非常深刻的印象. 根据自己的判断,语音识别系统还是非常有用的. 以自己的实际需求来看: 1.中国象棋中的应用. 中国象 ...

  5. HDU1969 Pie(二分搜索)

    题目大意是要办生日Party,有n个馅饼,有f个朋友.接下来是n个馅饼的半径.然后是分馅饼了, 注意咯自己也要,大家都要一样大,形状没什么要求,但都要是一整块的那种,也就是说不能从两个饼中 各割一小块 ...

  6. net基础题

    1. 简述 private. protected. public. internal 修饰符的访问权限. 答 . private :   私有成员, 在类的内部才可以访问. protected : 保 ...

  7. 软件——机器学习与Python,输入输出的用法

    转自:http://www.cnblogs.com/graceting/p/3875438.html 输入很简单 x = input("Please input x:") Plea ...

  8. Day1:注释

    一.注释方法 1.单行注释用#,本行#号后的内容为注释内容,不执行 2.多行用三个单引号或三个双引号标注,中间内容为注释,不执行 二.其他相关内容 三个引号中的内容还可以当作字符串赋值给变量,可以同时 ...

  9. GO语言学习(十)Go 语言条件语句

    Go 语言提供了以下几种条件判断语句: 语句 描述 if 语句 if 语句 由一个布尔表达式后紧跟一个或多个语句组成. if...else 语句 if 语句 后可以使用可选的 else 语句, els ...

  10. js进阶 13-2 jquery动画滑动效果哪些注意事项

    js进阶 13-2 jquery动画滑动效果哪些注意事项 一.总结 一句话总结:滑动里面这里up是隐藏,down是显示. 1.jquery动画默认的两个切换效果是什么(swing默认和linear的区 ...