json ajax 关键字数组,ajax响应json字符串和json数组的方法

be45eb6c5fd66d11a803e0291ef8bfd0.png

这次给大家带来ajax响应json字符串和json数组的方法,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);

}

}

前台页面

pageEncoding="UTF-8"%>

Json
username
id

UsernameId

// 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

var trObj = document.createElement("tr");

trObj.innerHTML = "

" + obj[i].name + "" + obj[i].id + "";

oFragment.appendChild(trObj);

}

// 将行数据添加在表格的tBody部分

document.getElementById("tb").appendChild(oFragment);

}

};

xhr.send(null);

}

页面效果图

0771ac6c0fcedc7484ec1ce309bcc19b.png

点击 JsonStr 和 JsonArr 按钮后的效果

73ac593fcec275a7d4d4f12fccd2df14.png

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

相信看了本文案例你已经掌握了方法,更多精彩请关注php教程其它相关文章!

推荐阅读:

Ajax如何实现城市二级联动

AJAX跨域请求JSONP获取JSON数据步骤详解(附代码)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值