日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JSON 分析数据格式

發布時間:2024/10/12 javascript 69 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JSON 分析数据格式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2014年4月26日本10:55:15 從三月初開始,并JSON戰斗。學校不教怎樣做,己。。大規模的搜索啊。發表這篇文章,喜歡我和不知道如何開始的新手!


和 XML 如。JSON 也是基于純文本數據格公式。 JSON 天生是為 JavaScript 準備的。因此。JSON 的數據格式很easy,您能夠用 JSON 傳輸一個簡單的 String,Number,Boolean,也能夠傳輸一個數組,或者一個復雜的 Object 對象。

String。Number 和 Boolean 用 JSON 表示很easy。

比如,用 JSON 表示一個簡單的 String “ abc ”,其格式為:
"abc"

除了字符 ",\,/ 和一些控制符(\b,\f,\n。\r,\t)須要編碼外,其它 Unicode 字符能夠直接輸出。下圖是一個 String 的完整表示結構:

圖 1. String 的完整表示結構

一個 Number 能夠依據整型或浮點數表演示樣例如以下:

圖 2. Number 的表示結構


這與絕大多數編程語言的表示方法一致,比如:
12345(整數)
-3.9e10(浮點數)
Boolean 類型表示為 true 或 false 。此外,JavaScript 中的 null 被表示為 null,注意。true、false 和 null 都沒有雙引號。否則將被視為一個 String 。
JSON 還能夠表示一個數組對象,使用 [] 包括全部元素。每一個元素用逗號分隔,元素能夠是隨意的 Value,比如,下面數組包括了一個 String,Number,Boolean 和一個 null:

["abc",12345,false,null]
{"city":"Beijing","street":" Chaoyang Road ","postcode":100025}


Object 對象在 JSON 中是用 {} 包括一系列無序的 Key-Value 鍵值對表示的。實際上此處的 Object 相當于 Java 中的 Map<String, Object>,而不是 Java 的 Class 。注意 Key 僅僅能用 String 表示。
比如,一個 Address 對象包括例如以下 Key-Value:

city:Beijing street:Chaoyang Road postcode:100025
用 JSON 表演示樣例如以下:

{"city":"Beijing","street":" Chaoyang Road ","postcode":100025}


當中 Value 也能夠是還有一個 Object 或者數組。因此。復雜的 Object 能夠嵌套表示,比如,一個 Person 對象包括 name 和 address 對象,能夠表演示樣例如以下:

{"name":"Michael","address": {"city":"Beijing","street":" Chaoyang Road ","postcode":100025} }


JavaScript 處理 JSON 數據
上面介紹了怎樣用 JSON 表示數據,接下來,我們還要解決怎樣在server端生成 JSON 格式的數據以便發送到client。以及client怎樣使用 JavaScript 處理 JSON 格式的數據。


我們先討論怎樣在 Web 頁面中用 JavaScript 處理 JSON 數據。我們通過一個簡單的 JavaScript 方法就能看到client怎樣將 JSON 數據表示給用戶:

function handleJson() { var j={"name":"Michael","address": {"city":"Beijing","street":" Chaoyang Road ","postcode":100025} }; document.write(j.name); document.write(j.address.city); }
假定server返回的 JSON 數據是上文的:


{"name":"Michael","address": {"city":"Beijing","street":" Chaoyang Road ","postcode":100025} }

僅僅需將其賦值給一個 JavaScript 變量。就能夠立馬使用該變量并更新頁面中的信息了,相比 XML 須要從 DOM 中讀取各種節點而言。JSON 的使用很容

易。我們須要做的不過發送一個 Ajax 請求。然后將server返回的 JSON 數據賦值給一個變量就可以。有很多 Ajax 框架早已包括了處理 JSON 數據的能力,比如 Prototype(一個流行的 JavaScript 庫:http://prototypejs.org)提供了 evalJSON() 方法,能直接將server返回的 JSON 文本變成一個 JavaScript 變量:


new Ajax.Request("http://url", { method: "get", onSuccess: function(transport) { var json = transport.responseText.evalJSON(); // TODO: document.write(json.xxx); } });
server端輸出 JSON 格式數據
以下我們討論怎樣在server端輸出 JSON 格式的數據。以 Java 為例。我們將演示將一個 Java 對象編碼為 JSON 格式的文本。


將 String 對象編碼為 JSON 格式時。僅僅需處理好特殊字符就可以。

另外,必須用 (") 而非 (') 表示字符串:


static String string2Json(String s) { StringBuilder sb = new StringBuilder(s.length()+20); sb.append('\"'); for (int i=0; i<s.length(); i++) { char c = s.charAt(i); switch (c) { case '\"': sb.append("\\\""); break; case '\\': sb.append("\\\\"); break; case '/': sb.append("\\/"); break; case '\b': sb.append("\\b"); break; case '\f': sb.append("\\f");
break; case '\n': sb.append("\\n"); break; case '\r': sb.append("\\r"); break; case '\t': sb.append("\\t"); break; default: sb.append(c); } } sb.append('\"'); return sb.toString(); }
將 Number 表示為 JSON 就easy得多,利用 Java 的多態,我們能夠處理 Integer,Long,Float 等多種 Number 格式:

static String number2Json(Number number) { return number.toString(); }Boolean 類型也能夠直接通過 toString() 方法得到 JSON 的表示:static String boolean2Json(Boolean bool) { return bool.toString(); }要將數組編碼為 JSON 格式。能夠通過循環將每個元素編碼出來:


static String array2Json(Object[] array) { if (array.length==0) return "[]";StringBuilder sb = new StringBuilder(array.length << 4); sb.append('['); for (Object o : array) { sb.append(toJson(o)); sb.append(','); } // 將最后加入的 ',' 變為 ']': sb.setCharAt(sb.length()-1, ']'); return sb.toString(); }最后。我們須要將 Map<String, Object> 編碼為 JSON 格式。由于 JavaScript 的 Object 實際上相應的是 Java 的 Map<String, Object> 。該方法例如以下:

static String map2Json(Map<String, Object> map) { if (map.isEmpty()) return "{}"; StringBuilder sb = new StringBuilder(map.size() << 4); sb.append('{'); Set<String> keys = map.keySet(); for (String key : keys) { Object value = map.get(key); sb.append('\"'); sb.append(key); sb.append('\"'); sb.append(':'); sb.append(toJson(value)); sb.append(','); } // 將最后的 ',' 變為 '}': sb.setCharAt(sb.length()-1, '}'); return sb.toString(); }為了統一處理隨意的 Java 對象。我們編寫一個入口方法 toJson(Object),可以將隨意的 Java 對象編碼為 JSON 格式:


public static String toJson(Object o) { if (o==null) return "null"; if (o instanceof String) return string2Json((String)o); if (o instanceof Boolean) return boolean2Json((Boolean)o); if (o instanceof Number) return number2Json((Number)o); if (o instanceof Map) return map2Json((Map<String, Object>)o); if (o instanceof Object[]) return array2Json((Object[])o); throw new RuntimeException("Unsupported type: " + o.getClass().getName()); }
我們并未對 Java 對象作嚴格的檢查。不被支持的對象(比如 List)將直接拋出 RuntimeException 。此外。為了保證輸出的 JSON 是有效的,Map<String, Object> 對象的 Key 也不能包括特殊字符。細心的讀者可能還會發現循環引用的對象會引發無限遞歸,比如。精心構造一個循環引用的 Map,就能夠檢測到 StackOverflowException:


@Test(expected=StackOverflowError.class) public void testRecurrsiveMap2Json() { Map<String, Object> map = new HashMap<String, Object>(); map.put("key", map); JsonUtil.map2Json(map); }
好在server處理的 JSON 數據終于都應該轉化為簡單的 JavaScript 對象,因此。遞歸引用的可能性非常小。
最后,通過 Servlet 或 MVC 框架輸出 JSON 時,須要設置正確的 MIME 類型(application/json)和字符編碼。

假定server使用 UTF-8 編碼,則能夠使用下面代碼輸出編碼后的 JSON 文本:

response.setContentType("application/json;charset=UTF-8"); response.setCharacterEncoding("UTF-8");PrintWriter pw = response.getWriter(); pw.write(JsonUtil.toJson(obj)); pw.flush();

小結
JSON 已經是 JavaScript 標準的一部分。眼下,主流的瀏覽器對 JSON 支持都很完好。應用 JSON,我們能夠從 XML 的解析中擺脫出來。對那些應用 Ajax 的 Web 2.0 站點來說,JSON 確實是眼下最靈活的輕量級方案。

這是我從PDF里截圖的,假設看著不方便請到我的資源里去下載!

JSON數據格公式.pdf



版權聲明:本文博客原創文章,博客,未經同意,不得轉載。

轉載于:https://www.cnblogs.com/mengfanrong/p/4609695.html

總結

以上是生活随笔為你收集整理的JSON 分析数据格式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。