JSON是一種取代XML的數據結構,和xml相比,它更小巧但描述能力卻不差,由于它的小巧所以網(wǎng)絡(luò )傳輸數據將減少更多流量從而加快速度, 那么,JSON到底是什么? JSONに関する、JSONPに関する。
var str1 = '{ "name": "cxh", "sex": "man" }'; var data=eval("("+str1+")");//轉換為json對象//data =(new alert (data.name);//會(huì )顯示出cxh
不過(guò)eval解析json有安全隱患!
現在大多數瀏覽器(IE8及以上,Chrome和Firefox差不多全部)自帶原生JSON對象,提供JSON.parse()方法解析JSON,提供JSON.stringify()方法生成JSON,請使用這兩個(gè)方法!
如果擔心parse()對對象拋異常,可以加一個(gè)封裝函數:
JSON.pParse = function( tar ) { if( typeof( tar ) === 'string' ) { return JSON.parse( tar ); } else { return tar; } };
oschinaの「我土鱉」が修正法を提供してくれてありがとう。
為了方便地處理JSON數據,JSON提供了json.js包,下載地址: http://lib.sinaapp.com/js/json2/json2.js
データ転送プロセスでは、JSONはテキスト、つまり文字列として渡されます。一方、JSはJSONオブジェクトを操作するため、JSONオブジェクトとJSON文字列の相互変換が重要です。例えば:
JSON文字列
var str1 = '{ "name": "cxh", "sex": "man" }';
JSONオブジェクト:
var str2 = { "name": "cxh", "sex": "man" };
一、JSON文字列をJSONオブジェクトに変換
str1を使用するには、以下のようにJSONオブジェクトに変換する必要があります:
var obj = eval('(' + str + ')');//由JSON字符串轉換為JSON對象
あるいは(あるいは)
var obj = str.parseJSON(); //由JSON字符串轉換為JSON對象
あるいは(あるいは)
var obj = JSON.parse(str); //由JSON字符串轉換為JSON對象
それでは、以下のように読み取ることができます:
Alert(obj.name); Alert(obj.sex);
特に注意:objが既にJSONオブジェクトの場(chǎng)合、eval()関數で変換(たとえ複數回でも)した後もJSONオブジェクトのままですが、parseJSON()関數で処理すると問(wèn)題が発生します(構文エラーが投げられます)。
二、JSONオブジェクトをJSON文字列に変換するには、toJSONString()またはグローバルのJSON.stringify()を使用できます。
例えば:
var last=obj.toJSONString(); //將JSON對象轉化為JSON字符
あるいは(あるいは)
var last=JSON.stringify(obj); //將JSON對象轉化為JSON字符 alert(last);
注意してください。
上記の要領(lǐng)では、eval()関數はJS內蔵だが、他はjson.jsパッケージから來(lái)ている。新しいJSONはAPIを変更し、JSON.stringify()とJSON.parse()の両方をJavascriptの內蔵オブジェクトに統合。前者はObject.toJSONString()、後者はString.parseJSON()に変わった。toJSONString()やparseJSON()が見(jiàn)つからない場(chǎng)合は、jsonパッ
文法:
jQuery.getJSON(url,data,success(data,status,xhr))
パラメータ:
パラメータ | 記述 |
---|---|
url | 必要です。要求を送信するURLを指定します。 |
data | オプションで、サーバーに送信するデータを指定。 |
success(data,status,xhr) |
可選。規定當請求成功時(shí)運行的函數。
額外的參數:
|
用例:用例(ユースケース)
$.getJSON("test.js", function(json){ alert("JSON Data: " + json.users[3].name); });
這個(gè)需要json-lib.jar包支持 該jar下載地址: ダウンロードしてクリックしてください。
//JSON對象 JSONObject的使用 String str1 = "{ 'name': 'cxh', 'sex': '1' }"; JSONObject obj = JSONObject.fromObject(str1); String name = obj.getString("name"); //直接返回字符串型 cxh Object nameo = obj.get("name"); //直接返回對象型的cxh int age = obj.getInt("sex"); //直接返回int型的sex //JSON數組對象 JSONArray的運用 String jsonArrStr = "[{ 'name': 'cxh', 'sex': '1','website':'http://www.foxrdc.com' },{ 'name': '三少', 'sex': '1','website':'http://www.ij2ee.com' }]"; JSONArray array = JSONArray.fromObject(jsonArrStr); int size = array.size(); //獲取JSON數組大小 JSONObject jo = array.getJSONObject(0);//取第一個(gè)JSON對象 for(int i=0;i<size;i++){ JSONObject jo1 = array.getJSONObject(i); System.out.println(jo1.getString("website")); //循環(huán)返回網(wǎng)址 } //序列化Bean對象為JSON對象 User user = new User(); user.setName("cxh"); user.setSex(1); user.setWebsite("http://www.foxrdc.com"); JSONObject jo2 = JSONObject.fromObject(user); System.out.println(jo2.toString()); //則會(huì )輸出 { 'name': 'cxh', 'sex': '1','website':'http://www.foxrdc.com' }
一、json_encode() → jsonエンコード()
この関數は配列やオブジェクトをJSON形式に変換するために使用されます。配列の変換例をまず見(jiàn)てみましょう:
$arr = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5); echo json_encode($arr);
結果は:
{"a":1,"b":2,"c":3,"d":4,"e":5}
もう一つのオブジェクト変換の例を見(jiàn)てみましょう:
$obj->body = 'another post'; $obj->id = 21; $obj->approved = true; $obj->favorite_count = 1; $obj->status = NULL; echo json_encode($obj);
結果は:
{ "body":"another post", "id":21, "approved":true, "favorite_count":1, "status":null }
JSONはUTF-8エンコードの文字のみを受け入れるため、json_encode()の引數はUTF-8エンコードでなければなりません。GB2312で中國語(yǔ)を使用したり、ISO-8859-1で外國語(yǔ)を使用する際には特に注意が必要です。
二、インデックス配列と関連配列
PHPには2種類(lèi)の配列があります。一つは値(value)のみを保存するインデックス配列(indexed array)、もう一つは名前と値の対(name/value)を保存する連想配列(associative array)です。JavaScriptは連想配列をサポートしていないため、json_encode()はインデックス配列を配列形式、連想配列をオブジェクト形式に変換します。
$arr = Array('one', 'two', 'three'); echo json_encode($arr);
結果は:
["one","two","three"]
連想配列に変更すると:
$arr = Array('1'=>'one', '2'=>'two', '3'=>'three'); echo json_encode($arr);
結果は変わった:
{"1":"one","2":"two","3":"three"}
注意,數據格式從"[]"(數組)變成了"{}"(對象)。
如果你需要將"索引數組"強制轉化成"對象",可以這樣寫(xiě):
json_encode( (object)$arr );
または:
json_encode ( $arr, JSON_FORCE_OBJECT );
三、クラス(class)の変換
以下はPHPのクラスです:
class Foo { const ERROR_CODE = '404'; public $public_ex = 'this is public'; private $private_ex = 'this is private!'; protected $protected_ex = 'this should be protected'; public function getErrorCode() { return self::ERROR_CODE; } }
現在、このクラスのインスタンスをJSONに変換します:
$foo = new Foo; $foo_json = json_encode($foo); echo $foo_json;
出力結果は:
{"public_ex":"this is public"}
見(jiàn)ての通り、public変數以外のもの(定數、private変數、メソッドなど)は失われています。
JSONデコード関數()
この関數はJSONテキストを対応するPHPデータ構造に変換するために使用されます。以下に例を示します:
$json = '{"foo": 12345}'; $obj = json_decode($json); print $obj->{'foo'}; // 12345
通常、json_decode()はPHPオブジェクトを返すのが一般的ですが、例えば:
$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}'; var_dump(json_decode($json));
結果としてPHPオブジェクトが生成されます:
object(stdClass)#1 (5) { ["a"] => int(1) ["b"] => int(2) ["c"] => int(3) ["d"] => int(4) ["e"] => int(5) }
PHP連想配列を強制的に生成するには、json_decode()に引數trueを追加します:
$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}'; var_dump(json_decode($json,true));
結果として、関連配列が生成されました:
array(5) { ["a"] => int(1) ["b"] => int(2) ["c"] => int(3) ["d"] => int(4) ["e"] => int(5) }
5. json_decode()のよくあるエラー
$bad_json = "{ 'bar': 'baz' }"; $bad_json = '{ bar: "baz" }'; $bad_json = '{ "bar": "baz", }';
對這三個(gè)字符串執行json_decode()都將返回null,并且報錯。
第一個(gè)的錯誤是,json的分隔符(delimiter)只允許使用雙引號,不能使用單引號。第二個(gè)的錯誤是,json名值對的"名"(冒號左邊的部分),任何情況下都必須使用雙引號。第三個(gè)的錯誤是,最后一個(gè)值之后不能添加逗號(trailing comma)。
另外,json只能用來(lái)表示對象(object)和數組(array),如果對一個(gè)字符串或數值使用json_decode(),將會(huì )返回null。
var_dump(json_decode("Hello World")); //null
import json str1 = '{ "name": "cxh", "sex": "1" }' # 或者 # str1 = """{ "name": "cxh", "sex": "1" }""" # 或者 # str1 = "{ \"name\": \"cxh\", \"sex\": \"1\" }" obj = json.loads(str1) print(obj["name"]) print(obj["sex"]) # 由于出現中文,記得文件頭加入 # coding:utf8 json_arr_str = """[{ "name": "cxh", "sex": "1","website":"http://www.foxrdc.com" },{ "name": "我的", "sex": "1","website":"http://www.foxrdc.com" }]""" arr = json.loads(json_arr_str) for o in arr: print(o["name"]) print(o["sex"]) print(o["website"])
ありがとうございます、張東桂さんが提供したコード
需要的dll:Newtonsoft.Json.dll, DLL公式サイトダウンロード
//讀取簡(jiǎn)單的json string json="{\"username\":\"張三\"}"; string username = string.Empty; JObject jObj=JObject.Parse(json); //進(jìn)行格式化 username = jObj["username"].ToString(); Console.WriteLine(username); //讀取嵌套對象的json json = "{\"username\":\"張三\",data:{\"address\":\"福建廈門(mén)\"}}"; jObj = JObject.Parse(json); string address = string.Empty; address = jObj["data"]["address"].ToString(); Console.WriteLine(address); //讀取數組,操作方式與數組類(lèi)似 json = "{\"username\":\"張三\",data:[{\"address\":\"福建廈門(mén)\"},{\"address\":\"福建福州\"}]}"; jObj = JObject.Parse(json); address = string.Empty; address = jObj["data"][0]["address"].ToString()+","+ jObj["data"][1]["address"].ToString(); Console.WriteLine(address); Console.ReadLine();
黃明輝さんが提供したコードありがとうございます。
需要的dll:Newtonsoft.Json.dll, DLL公式サイトダウンロード
//JSON字符串轉字典: NSString *str1 = @"{\"name\":\"cxh\",\"sex\":\"1\"}"; NSData *jsonData1 = [str1 dataUsingEncoding:NSUTF8StringEncoding]; NSError *error1; NSDictionary *jsonDic = [NSJSONSerialization JSONObjectWithData:jsonData1 options:NSJSONReadingMutableContainers error:&error1]; /* NSJSONReadingMutableContainers 創(chuàng )建結果為可變數組/字典 NSJSONReadingMutableLeaves 創(chuàng )建結果中字符串是可變字符串 NSJSONReadingAllowFragments 允許json最外層不是數組或字典 */ if (!error1) { NSLog(@"jsonDic is:%@",jsonDic); } else{ NSLog(@"error:%@",error1); } //字典轉JSON字符串 NSError *error2 = nil; NSData *jsonData2 = [NSJSONSerialization dataWithJSONObject:jsonDic options:NSJSONWritingPrettyPrinted error:&error2]; if (!error2) { NSString *str2 = [[NSString alloc] initWithData:jsonData2 encoding:NSUTF8StringEncoding]; NSLog(@"json string is:%@",str2); } else{ NSLog(@"error:%@",error2); }
追加する內容があれば、コードと必要なライブラリを以下のメールアドレスに送ってください。ij2ee@139.com。採用された場(chǎng)合は、あなたのウェブサイトのリンクを追加できますよ。
最近使用した: