- 2023-05-20 13:15:09
- 2364 热度
- 0 评论
SpringMVC如果返回给Ajax内容的话,需要用一个注解@ResponseBody,返回内容的格式是自定义的,这里我返回一个Map,Map中有一个List和一个字符串。
一般返回时我们会把返回内容转为JSON即JSONObject,但是如果你不转化,直接返回也是可以的。
这里就写两个方法,一个转为JSONObject,一个没有转。
@RequestMapping(value = "/test") @ResponseBody public JSONObject test(HttpServletRequest request) { String a = request.getParameter("a"); String b = request.getParameter("b"); System.out.println("====>" + a); System.out.println("====>" + b); Map<String, Object> map = new HashMap<String, Object>(); List<String> list = new ArrayList<String>(); list.add(new String("a")); list.add(new String("b")); map.put("key1", list); map.put("key2", new String("i am key2")); JSONObject result = JSONObject.fromObject(map); return result; } @SuppressWarnings("unchecked") @RequestMapping(value = "/test2") @ResponseBody public Map test2(HttpServletRequest request) { String a = request.getParameter("a"); String b = request.getParameter("b"); System.out.println("====>" + a); System.out.println("====>" + b); Map<String, Object> map = new HashMap<String, Object>(); List<String> list = new ArrayList<String>(); list.add(new String("a")); list.add(new String("b")); map.put("key1", list); map.put("key2", new String("i am key2")); return map; }
打印收到的参数,这里并没有做处理。返回的内容格式可以从Java代码中看到。
HTML代码如下,注意导入JQuery,知道eval的使用(JSON简介与JS解析JSON )。基本使用格式都是一样的,传入参数,解析返回内容。
console.log()是在浏览器打印信息,你可以F12打开开发窗口,然后查看打印和一些其他信息。
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>Ajax测试-java無名</title> <script type="text/javascript" src="<%=basePath %>Scripts/jquery-1.7.2.js"></script> <script type="text/javascript"> function submitMe(){ var a=$('#a').val(); var b=$('#b').val(); // 注意对该路径权限上放行 var url="<%=request.getContextPath()%>/login/test"; $.ajax({ url:url, type:"post", async:false,// 声明ajax同步执行 data:{ "a":a, "b":b }, dataType:"text", success:function(data){ if(data!=null){ console.log("返回内容:"+data); var jsonObj = eval("(" + data + ")");//把总数据转成json if(jsonObj != null){ var key1 = jsonObj.key1; var key1Len = key1.length; //得到总数据的个数 if(key1Len>0){ for (var i = 0; i < key1Len; i++) { var obj = key1[i]; console.log("第"+i+"参数值:"+obj); } } console.log("=================="); var key2 = jsonObj.key2; console.log("key2值:"+key2); } } } }); } </script> </head> <body> <form action=""> <table> <tr> <td> <input name="a" id="a"/> </td> </tr> <tr> <td> <input name="b" id="b"/> </td> </tr> <tr> <td> <input type="button" onclick="submitMe()" value="Ajax提交"/> </td> </tr> </table> </form> </body> </html>
我这里写的是test,可以直接修改为test2,其他代码不动,效果一样。
浏览器点击后打印效果如下:
0 评论
留下评论
热门标签
- Spring(403)
- Boot(208)
- Spring Boot(187)
- Java(82)
- Cloud(82)
- Spring Cloud(82)
- Security(60)
- Spring Security(54)
- Boot2(51)
- Spring Boot2(51)
- Redis(31)
- SQL(29)
- Mysql(25)
- IDE(24)
- Dalston(24)
- MVC(22)
- JDBC(22)
- IDEA(22)
- mongoDB(22)
- Web(21)
- CLI(20)
- SpringMVC(19)
- Alibaba(19)
- SpringBoot(17)
- Docker(17)
- Git(16)
- Eclipse(16)
- Vue(16)
- ORA(15)
- JPA(15)
- Apache(15)
- Mybatis(14)
- Oracle(14)
- jdk(14)
- Tomcat(14)
- Linux(14)
- HTTP(14)
- XML(13)
- JdbcTemplate(13)
- OAuth(13)
- Nacos(13)
- Pro(13)
- Data(12)
- JSON(12)
- OAuth2(12)
- stream(11)
- int(11)
- Myeclipse(11)
- Bug(10)
- not(10)
- ast(9)
- maven(9)
- Map(9)
- Hystrix(9)
- Swagger(8)
- APP(8)
- Bit(8)
- API(8)
- session(8)
- Window(8)
- HTML(7)
- Github(7)
- JavaMail(7)
- Cache(7)
- File(7)
- IntelliJ(7)
- mail(7)
- windows(7)
- too(7)
- RabbitMQ(6)
- and(6)
- star(6)
- Excel(6)
- Log4J(6)
- pushlet(6)
- apt(6)
- read(6)
- Freemarker(6)
- WebFlux(6)
- JSP(6)
- Bean(6)
- error(6)
- nginx(6)
- Server(6)
- jar(6)
- ueditor(6)
- ehcache(6)
- UDP(6)
- JWT(5)
- rdquo(5)
- PHP(5)
- Struts(5)
- string(5)
- Syntaxhighlighter(5)
- script(5)
- Tool(5)
- Controller(5)
- swagger2(5)
- ldquo(5)
- input(5)