全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

最近上班太忙,晚上抽空整理一下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 


相关文章: 网站设计制作企业有哪些,抖音官网主页怎么设置?  php json中文编码为null的解决办法  如何快速使用云服务器搭建个人网站?  建站之星上传入口如何快速找到?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  如何用腾讯建站主机快速创建免费网站?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  如何在阿里云通过域名搭建网站?  建站之星CMS五站合一模板配置与SEO优化指南  如何配置IIS站点权限与局域网访问?  网站制作的步骤包括,正确网址格式怎么写?  公司网站设计制作厂家,怎么创建自己的一个网站?  建站之星备案流程有哪些注意事项?  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  网站制作公司,橙子建站是合法的吗?  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何通过VPS建站实现广告与增值服务盈利?  建站主机如何安装配置?新手必看操作指南  建站之星北京办公室:智能建站系统与小程序生成方案解析  建站之星2.7模板快速切换与批量管理功能操作指南  如何使用Golang table-driven基准测试_多组数据测量函数效率  如何彻底删除建站之星生成的Banner?  ,如何利用word制作宣传手册?  如何在Golang中指定模块版本_使用go.mod控制版本号  深圳企业网站制作设计,在深圳如何网上全流程注册公司?  广州建站公司哪家好?十大优质服务商推荐  电商网站制作价格怎么算,网上拍卖流程以及规则?  C++时间戳转换成日期时间的步骤和示例代码  如何确保FTP站点访问权限与数据传输安全?  如何用PHP工具快速搭建高效网站?  如何在宝塔面板创建新站点?  建站之星好吗?新手能否轻松上手建站?  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  如何在局域网内绑定自建网站域名?  如何通过免费商城建站系统源码自定义网站主题与功能?  如何在七牛云存储上搭建网站并设置自定义域名?  广东企业建站网站优化与SEO营销核心策略指南  测试制作网站有哪些,测试性取向的权威测试或者网站?  怎么将XML数据可视化 D3.js加载XML  如何用wdcp快速搭建高效网站?  定制建站流程步骤详解:一站式方案设计与开发指南  公司网站制作需要多少钱,找人做公司网站需要多少钱?  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  高性能网站服务器配置指南:安全稳定与高效建站核心方案  建站之星收费标准详解:套餐费用及年费价格表一览  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。