ajax响应json字符串和json数组的实例(详解)

发布时间 - 2026-01-10 23:06:37    点击率:

最近上班太忙,晚上抽空整理一下ajax请求中,后台返回json字符串和json数组的场景,以及前台的处理示例。

直接看代码。

json字符串的后台响应

package com.ajax;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/jsonStr")
public class JsonStr extends HttpServlet {

 /**
 * 
 */
 private static final long serialVersionUID = 1L;

 @Override
 protected void doGet(HttpServletRequest req, HttpServletResponse resp)
  throws ServletException, IOException {
 // 构造json对象
 String resStr = "{" + "name:" + "\"zhangsan\"," + "id:" + "\"id001\"" + "}";
 
 // 输出json对象到前台
 PrintWriter out = resp.getWriter();
 out.write(resStr);
 out.flush();
 out.close();
 }

 @Override
 protected void doPost(HttpServletRequest req, HttpServletResponse resp)
  throws ServletException, IOException {
 doGet(req, resp);
 }
}


json数组的后台响应

package com.ajax;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/jsonArr")
public class JsonArr extends HttpServlet {

 /**
 * 
 */
 private static final long serialVersionUID = 1L;

 @Override
 protected void doGet(HttpServletRequest req, HttpServletResponse resp)
  throws ServletException, IOException {
 // 构造json对象
 String resStr1 = "{" + "name:" + "\"zhangsan\"," + "id:" + "\"id001\"" + "}";
 String resStr2 = "{" + "name:" + "\"lisi\"," + "id:" + "\"id002\"" + "}";
 String resStr3 = "{" + "name:" + "\"wangwu\"," + "id:" + "\"id003\"" + "}";
 
 // 构造json数组
 String jsonArr = "[" + resStr1 + "," + resStr2 + "," + resStr3 + "]";
 
 // 输出json数组到前台
 PrintWriter out = resp.getWriter();
 out.write(jsonArr);
 out.flush();
 out.close();
 }

 @Override
 protected void doPost(HttpServletRequest req, HttpServletResponse resp)
  throws ServletException, IOException {
 doGet(req, resp);
 }
}

前台页面

<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Json</title>
</head>
<body>
 <br><br>
 <input type="button" value="JsonStr" onclick="jsonStr()" />
 <br><br>
 <table>
 <tr>
  <td>username</td>
  <td><input id="username"></td>
 </tr>
 <tr>
  <td>id</td>
  <td><input id="id"></td>
 </tr>
 </table>
 <br><br><br>
 <input type="button" value="JsonArr" onclick="jsonArr()" />
 <br><br>
 <table border="1" bordercolor="red">
 <caption>Json Array</caption>
 <thead>
  <tr>
  <th>Username</th>
  <th>Id</th>
  </tr>
 </thead>
 <tbody id="tb">
 </tbody>
 </table>
</body>
<script type="text/javascript">
 // json字符串处理方法
 function jsonStr() {
 var xhr = new XMLHttpRequest();
 xhr.open("get", "jsonStr");
 xhr.onreadystatechange = function(data) {
  if (xhr.readyState == 4 && xhr.status == 200) {
  // 将json字符串转换为json对象
  var obj = eval("(" + data.target.responseText + ")");
  document.getElementById("username").value = obj.name;
  document.getElementById("id").value = obj.id;
  }
 };
 xhr.send(null);
 }
 
 // json数组处理方法
 function jsonArr() {
 var xhr = new XMLHttpRequest();
 xhr.open("get", "jsonArr");
 xhr.onreadystatechange = function(data) {
  if (xhr.readyState == 4 && xhr.status == 200) {
  // 将json字符串转换为json数组
  var obj = eval("(" + data.target.responseText + ")");
  
  // 创建代码片段,用于存放表格行
  var oFragment = document.createDocumentFragment();
  
  // 根据json数组长度,产生行数据
  for (var i=0; i<obj.length; i++) {
   var trObj = document.createElement("tr");
   trObj.innerHTML = "<td>" + obj[i].name + "</td><td>" + obj[i].id + "</td>";
   oFragment.appendChild(trObj);
  }
  
  // 将行数据添加在表格的tBody部分
  document.getElementById("tb").appendChild(oFragment);
  }
 };
 xhr.send(null);
 }
</script>
</html>

页面效果图

点击 JsonStr 和 JsonArr 按钮后的效果

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

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

以上这篇ajax响应json字符串和json数组的实例(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# ajax  # 响应json  # Node.js如何响应Ajax的POST请求并且保存为JSON文件详解  # Ajax 接收服务器返回的json响应方法  # 原生JS实现Ajax跨域请求flask响应内容  # Js中使用hasOwnProperty方法检索ajax响应对象的例子  # 原生javascript的ajax请求及后台PHP响应操作示例  # 在AngularJs中设置请求头信息(headers)的方法及不同方法的比较  # selenium设置proxy、headers的方法(phantomjs、Chrome、Firefo  # node.js中的http.response.getHeader方法使用说明  # node.js中的http.response.setHeader方法使用说明  # node.js中的http.response.removeHeader方法使用说明  # js 使用ajax设置和获取自定义header信息的方法小结  # 给大家  # 转换为  # 都是  # 行数  # 一声  # 好了  # 仅供  # 希望能  # 这篇  # 不知道为什么  # 回调  # 小编  # 大家多多  # 太忙  # 整理一下  # 对了  # 晚上  # id  # zhangsan  # getWriter 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】  如何用wdcp快速搭建高效网站?  Laravel如何使用Livewire构建动态组件?(入门代码)  Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  googleplay官方入口在哪里_Google Play官方商店快速入口指南  Laravel事件监听器怎么写_Laravel Event和Listener使用教程  如何在建站宝盒中设置产品搜索功能?  如何快速辨别茅台真假?关键步骤解析  Firefox Developer Edition开发者版本入口  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  如何在服务器上三步完成建站并提升流量?  如何快速启动建站代理加盟业务?  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  Laravel Fortify是什么,和Jetstream有什么关系  js代码实现下拉菜单【推荐】  详解Android中Activity的四大启动模式实验简述  如何快速上传自定义模板至建站之星?  Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门  iOS UIView常见属性方法小结  教学论文网站制作软件有哪些,写论文用什么软件 ?  免费视频制作网站,更新又快又好的免费电影网站?  黑客入侵网站服务器的常见手法有哪些?  如何续费美橙建站之星域名及服务?  Python3.6正式版新特性预览  怎么用AI帮你为初创公司进行市场定位分析?  PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)  如何快速生成ASP一键建站模板并优化安全性?  Android利用动画实现背景逐渐变暗  网站优化排名时,需要考虑哪些问题呢?  如何将凡科建站内容保存为本地文件?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  焦点电影公司作品,电影焦点结局是什么?  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  佛山网站制作系统,佛山企业变更地址网上办理步骤?  Python文件异常处理策略_健壮性说明【指导】  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  如何为不同团队 ID 动态生成多个非值班状态按钮  Laravel怎么在Blade中安全地输出原始HTML内容  装修招标网站设计制作流程,装修招标流程?  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  网易LOFTER官网链接 老福特网页版登录地址  Laravel如何使用查询构建器?(Query Builder高级用法)  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】  Android滚轮选择时间控件使用详解  如何在香港服务器上快速搭建免备案网站?