最近上班太忙,晚上抽空整理一下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
相关文章:
如何选择CMS系统实现快速建站与SEO优化?
如何在香港服务器上快速搭建免备案网站?
建站之星上传入口如何快速找到?
如何实现建站之星域名转发设置?
建站之星后台管理:高效配置与模板优化提升用户体验
焦点电影公司作品,电影焦点结局是什么?
建站之星北京办公室:智能建站系统与小程序生成方案解析
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
建站10G流量真的够用吗?如何应对访问高峰?
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
如何选择服务器才能高效搭建专属网站?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
建站之星下载版如何获取与安装?
高性价比服务器租赁——企业级配置与24小时运维服务
建站之星安装模板失败:服务器环境不兼容?
广州顶尖建站服务:企业官网建设与SEO优化一体化方案
如何配置IIS站点权限与局域网访问?
如何通过多用户协作模板快速搭建高效企业网站?
如何在云主机快速搭建网站站点?
表情包在线制作网站免费,表情包怎么弄?
如何在阿里云购买域名并搭建网站?
如何通过免费商城建站系统源码自定义网站主题与功能?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
如何用PHP快速搭建CMS系统?
云南网站制作公司有哪些,云南最好的招聘网站是哪个?
如何快速上传建站程序避免常见错误?
网站网页制作专业公司,怎样制作自己的网页?
制作网页的网站有哪些,电脑上怎么做网页?
建站之星会员如何解锁更多建站功能?
如何挑选高效建站主机与优质域名?
可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?
无锡营销型网站制作公司,无锡网选车牌流程?
如何获取开源自助建站系统免费下载链接?
网站制作话术技巧,网站推广做的好怎么话术?
青浦网站制作公司有哪些,苹果官网发货地是哪里?
如何确认建站备案号应放置的具体位置?
如何选择PHP开源工具快速搭建网站?
C#怎么使用委托和事件 C# delegate与event编程方法
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
建站之星伪静态规则如何正确配置?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
TestNG的testng.xml配置文件怎么写
*请认真填写需求信息,我们会在24小时内与您取得联系。