关键词搜索

源码搜索 ×
×

操作JSON对象

发布2015-01-26浏览4406次

详情内容

JSON类型对象,最简单了,就是键值对,key:value、key:value、一直不停地key:value下去,层层嵌套,理论上多少层都可以,只要你喜欢。

可是,每次应用JSON,我都心烦意乱,甚至吓到面无人色。何哉?不懂咯,没有真正理解咯,拿到一个JSON对象,不知道如何去使用它,如何去读取里面的数据。

只能够一点一点地记录一些心得,期待量变达成质变,化蛹成蝶,肩胛骨处长出一对翅膀来。


1、JS里面使用

1)用key直接访问对应的value

比如:

  1. var jsonobj ={"total":106,"rows":[{},{},{}.....]}
  2. alert(jsonobj.total);

将字符串转化成json:
var jsonobj = JSON.parse(str);

注意!!!str里的json元素,务必是双引号分隔,而不能是单引号!!!!


2)遍历key

  1. var smsTypeDesc = {"4":"回访短信","3":"邮件短信","aa":"测试短信"};
  2. function EnumaKey(){
  3. for(var key in smsTypeDesc){
  4. alert(key);
  5. }
  6. }
  7. function GetVal(){
  8. var key = prompt("请输入要查询的key","4");
  9. if("undefined"==typeof(smsTypeDesc)) return;
  10. if("undefined"==typeof(smsTypeDesc[key])){
  11. alert("输入的key:"+key+", 在json对象中不存在!");
  12. return;
  13. }
  14. alert("您输入的key是:"+key + ",该key所对应的值是:"+smsTypeDesc[key]);
  15. }
  16. function GetValByKey(){
  17. alert(smsTypeDesc.aa);
  18. }

本例子摘自  http://blog.csdn.net/love__coder/article/details/7532616


3、提交或获取服务器端的JSON数据

  1. $.ajax({
  2. url: "/api/customview/SetTags?account=" + _index_account,
  3. data: JSON.stringify(effectRow),
  4. dataType: "json",
  5. type: "POST",
  6. contentType: "application/json; charset=utf-8",
  7. success: function (data) {
  8. _dg.datagrid('acceptChanges');
  9. if (data == true) {
  10. if (setTagsCallback != null) setTagsCallback();
  11. alert("OK");
  12. } else {
  13. alert("failed");
  14. }
  15. },
  16. error: function (XMLHttpRequest, textStatus, errorThrown) {
  17. alert(textStatus + ": " + errorThrown);
  18. }
  19. });

2、.NET里使用

.NET中操作JSON,非newtonsoft.json莫属。

newtonsoft.json里面的类型,目前来看,有以下类型:


JObject

 用于操作JSON对象
JArray
 用语操作JSON数组
JValue
 表示数组中的值
JProperty
 表示对象中的属性,以"key/value"形式
JToken
 用于存放Linq to JSON查询后的结果


参考文章:http://www.cnblogs.com/usharei/archivehttps://files.jxasp.com/image/2012/04https://files.jxasp.com/image/24https://files.jxasp.com/image/2467578.html

有代码有J8:

[csharp]  view plain copy
  1. using Newtonsoft.Json;  
  2.   
  3. JObject json = ...  
  4.   
  5. JToken[] jps = json["records"][0].ToArray();  
  6. List<ItemInfo> cols = json["columns"].ToObject<List<ItemInfo>>();  
  7.   
  8. ……  
  9.   
  10. JArray array = new JArray();  
  11. array.Add(data);  
  12. Tuple<int, JObject> tuple = customViewService.UpdateDataByView(ProjectId, account, array, viewId);  
  13. JObject ret = new JObject();  
  14. ret.Add(new JProperty("rows", array));  
  15. ret.Add(new JProperty("result", tuple.Item1 > 0));  

遍历,在不清楚该JSON的结构情况下:

[csharp]  view plain copy
  1. JsonTextReader reader = new JsonTextReader(new StringReader(sjson));  
  2. StringBuilder sb = new StringBuilder("");  
  3. while (reader.Read())  
  4. {  
  5.     if (reader.Value != null)  
  6.         sb.Append(String.Format("Token: {0}, Value: {1}\r\n", reader.TokenType, reader.Value));  
  7.     else  
  8.         sb.Append(String.Format("Token: {0}\r\n", reader.TokenType));  
  9. }  

相关技术文章

点击QQ咨询
开通会员
返回顶部
×
微信扫码支付
微信扫码支付
确定支付下载
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
  • 支付宝付款
确定支付下载