婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > ajax響應json字符串和json數組的實例(詳解)

ajax響應json字符串和json數組的實例(詳解)

熱門標簽:河間市地圖標注app 大眾點評400電話怎么申請 立陶宛地圖標注 東平縣地圖標注app 怎樣在地圖標注文字 電銷機器人 長春 中國地圖標注不明確情況介紹表 上海企業外呼系統價錢 地圖標注推銷坑人

最近上班太忙,晚上抽空整理一下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; iobj.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數組的實例(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Node.js如何響應Ajax的POST請求并且保存為JSON文件詳解
  • Ajax 接收服務器返回的json響應方法
  • 原生JS實現Ajax跨域請求flask響應內容
  • Js中使用hasOwnProperty方法檢索ajax響應對象的例子
  • 原生javascript的ajax請求及后臺PHP響應操作示例
  • 在AngularJs中設置請求頭信息(headers)的方法及不同方法的比較
  • selenium設置proxy、headers的方法(phantomjs、Chrome、Firefox)
  • node.js中的http.response.getHeader方法使用說明
  • node.js中的http.response.setHeader方法使用說明
  • node.js中的http.response.removeHeader方法使用說明
  • js 使用ajax設置和獲取自定義header信息的方法小結

標簽:四川 銅川 玉樹 遼寧 本溪 益陽 內江 營口

巨人網絡通訊聲明:本文標題《ajax響應json字符串和json數組的實例(詳解)》,本文關鍵詞  ajax,響應,json,字符串,和,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ajax響應json字符串和json數組的實例(詳解)》相關的同類信息!
  • 本頁收集關于ajax響應json字符串和json數組的實例(詳解)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 云林县| 新平| 雅安市| 盘山县| 沅陵县| 锡林郭勒盟| 榆社县| 镇赉县| 裕民县| 恩施市| 绥阳县| 栾川县| 新干县| 延川县| 平阴县| 怀集县| 荃湾区| 山阴县| 池州市| 阳江市| 霸州市| 普洱| 盈江县| 那曲县| 平顶山市| 锡林浩特市| 潞城市| 陇川县| 宝山区| 屏东县| 富裕县| 原平市| 上栗县| 呼玛县| 漳浦县| 什邡市| 海口市| 确山县| 普兰县| 江山市| 阿鲁科尔沁旗|