ajax响应json字符串和json数组

喜欢ヅ旅行 2022-08-08 13:45 375阅读 0赞
  1. 最近上班太忙,晚上抽空整理一下ajax请求中,后台返回json字符串和json数组的场景,以及前台的处理示例。
  2. 直接看代码。

json字符串的后台响应

  1. package com.ajax;
  2. import java.io.IOException;
  3. import java.io.PrintWriter;
  4. import javax.servlet.ServletException;
  5. import javax.servlet.annotation.WebServlet;
  6. import javax.servlet.http.HttpServlet;
  7. import javax.servlet.http.HttpServletRequest;
  8. import javax.servlet.http.HttpServletResponse;
  9. @WebServlet("/jsonStr")
  10. public class JsonStr extends HttpServlet {
  11. /**
  12. *
  13. */
  14. private static final long serialVersionUID = 1L;
  15. @Override
  16. protected void doGet(HttpServletRequest req, HttpServletResponse resp)
  17. throws ServletException, IOException {
  18. // 构造json对象
  19. String resStr = "{" + "name:" + "\"zhangsan\"," + "id:" + "\"id001\"" + "}";
  20. // 输出json对象到前台
  21. PrintWriter out = resp.getWriter();
  22. out.write(resStr);
  23. out.flush();
  24. out.close();
  25. }
  26. @Override
  27. protected void doPost(HttpServletRequest req, HttpServletResponse resp)
  28. throws ServletException, IOException {
  29. doGet(req, resp);
  30. }
  31. }

json数组的后台响应

  1. package com.ajax;
  2. import java.io.IOException;
  3. import java.io.PrintWriter;
  4. import javax.servlet.ServletException;
  5. import javax.servlet.annotation.WebServlet;
  6. import javax.servlet.http.HttpServlet;
  7. import javax.servlet.http.HttpServletRequest;
  8. import javax.servlet.http.HttpServletResponse;
  9. @WebServlet("/jsonArr")
  10. public class JsonArr extends HttpServlet {
  11. /**
  12. *
  13. */
  14. private static final long serialVersionUID = 1L;
  15. @Override
  16. protected void doGet(HttpServletRequest req, HttpServletResponse resp)
  17. throws ServletException, IOException {
  18. // 构造json对象
  19. String resStr1 = "{" + "name:" + "\"zhangsan\"," + "id:" + "\"id001\"" + "}";
  20. String resStr2 = "{" + "name:" + "\"lisi\"," + "id:" + "\"id002\"" + "}";
  21. String resStr3 = "{" + "name:" + "\"wangwu\"," + "id:" + "\"id003\"" + "}";
  22. // 构造json数组
  23. String jsonArr = "[" + resStr1 + "," + resStr2 + "," + resStr3 + "]";
  24. // 输出json数组到前台
  25. PrintWriter out = resp.getWriter();
  26. out.write(jsonArr);
  27. out.flush();
  28. out.close();
  29. }
  30. @Override
  31. protected void doPost(HttpServletRequest req, HttpServletResponse resp)
  32. throws ServletException, IOException {
  33. doGet(req, resp);
  34. }
  35. }

前台页面

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  7. <title>Json</title>
  8. </head>
  9. <body>
  10. <br><br>
  11. <input type="button" value="JsonStr" οnclick="jsonStr()" />
  12. <br><br>
  13. <table>
  14. <tr>
  15. <td>username</td>
  16. <td><input id="username"></td>
  17. </tr>
  18. <tr>
  19. <td>id</td>
  20. <td><input id="id"></td>
  21. </tr>
  22. </table>
  23. <br><br><br>
  24. <input type="button" value="JsonArr" οnclick="jsonArr()" />
  25. <br><br>
  26. <table border="1" bordercolor="red">
  27. <caption>Json Array</caption>
  28. <thead>
  29. <tr>
  30. <th>Username</th>
  31. <th>Id</th>
  32. </tr>
  33. </thead>
  34. <tbody id="tb">
  35. </tbody>
  36. </table>
  37. </body>
  38. <script type="text/javascript">
  39. // json字符串处理方法
  40. function jsonStr() {
  41. var xhr = new XMLHttpRequest();
  42. xhr.open("get", "jsonStr");
  43. xhr.onreadystatechange = function(data) {
  44. if (xhr.readyState == 4 && xhr.status == 200) {
  45. // 将json字符串转换为json对象
  46. var obj = eval("(" + data.target.responseText + ")");
  47. document.getElementById("username").value = obj.name;
  48. document.getElementById("id").value = obj.id;
  49. }
  50. };
  51. xhr.send(null);
  52. }
  53. // json数组处理方法
  54. function jsonArr() {
  55. var xhr = new XMLHttpRequest();
  56. xhr.open("get", "jsonArr");
  57. xhr.onreadystatechange = function(data) {
  58. if (xhr.readyState == 4 && xhr.status == 200) {
  59. // 将json字符串转换为json数组
  60. var obj = eval("(" + data.target.responseText + ")");
  61. // 创建代码片段,用于存放表格行
  62. var oFragment = document.createDocumentFragment();
  63. // 根据json数组长度,产生行数据
  64. for (var i=0; i<obj.length; i++) {
  65. var trObj = document.createElement("tr");
  66. trObj.innerHTML = "<td>" + obj[i].name + "</td><td>" + obj[i].id + "</td>";
  67. oFragment.appendChild(trObj);
  68. }
  69. // 将行数据添加在表格的tBody部分
  70. document.getElementById("tb").appendChild(oFragment);
  71. }
  72. };
  73. xhr.send(null);
  74. }
  75. </script>
  76. </html>

页面效果图

SouthEast

点击 JsonStr 和 JsonArr 按钮后的效果

SouthEast 1

好了,整理完毕,示例仅供学习。

  1. 对了,有一点疑惑,之前回调函数中,获取响应数据的时候,都是直接通过data.responseText 来获取的,今天的代码中必须使用data.target.responseText,不知道为什么?有知道的朋友烦请告知一声,非常感谢。

发表评论

表情:
评论列表 (有 0 条评论,375人围观)

还没有评论,来说两句吧...

相关阅读