国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

將List對象列表轉換成JSON格式的類實現方法

2019-11-20 09:33:53
字體:
來源:轉載
供稿:網友

JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式。易于人閱讀和編寫。同時也易于機器解析和生成。它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一個子集。 JSON采用完全獨立于語言的文本格式,但是也使用了類似于C語言家族的習慣(包括C, C++, C#, Java, JavaScript, Perl, Python等)。這些特性使JSON成為理想的數據交換語言。引用于[http://www.json.org/json-zh.html]

一般應用中,我習慣性地把結果集以更通用的IList<object>對象列表方式保存(可能會對性能有些影響)來保證類間交互時的通用性,降低函數功能對具體類的耦合。但AJAX調用時,還需要把對象列表轉換成JSON數據交給前端顯示。有麻煩。

研究了一下JSON的對象定義和集合定義

 感覺利用反射來生成JSON還比較方便。代碼如下:

Code//// ObjectListToJSON// Copyright (c) 2008 pcode. All rights reserved.//// Author(s):////   pcode,jy@cjlu.edu.cn// 此類用于將List<object>轉換為json數據格式// 目前僅能處理一個object的基礎數據類型而且對[ { }] /等對json有傷害影響特殊符號沒有特殊處理// 希望有兄弟繼續完善using System.Reflection;using System.Collections.Generic;public class ObjectListToJSON{  #region 反射一個對象所有屬性和屬性值和將一個對象的反射結果封裝成jsons格式  /**     * 對象的全部屬性和屬性值。用于填寫json的{}內數據     * 生成后的格式類似     * "屬性1":"屬性值"     * 將這些屬性名和屬性值寫入字符串列表返回     * */  private List<string> GetObjectProperty(object o)  {    List<string> propertyslist = new List<string>();    PropertyInfo[] propertys = o.GetType().GetProperties();    foreach (PropertyInfo p in propertys)    {      propertyslist.Add("/"" + p.Name.ToString() + "/":/"" + p.GetValue(o, null) + "/"");    }    return propertyslist;  }  /**   * 將一個對象的所有屬性和屬性值按json的格式要求輸入為一個封裝后的結果。   *   * 返回值類似{"屬性1":"屬性1值","屬性2":"屬性2值","屬性3":"屬性3值"}   *    * */  private string OneObjectToJSON(object o)  {    string result = "{";    List<string> ls_propertys = new List<string>();    ls_propertys = GetObjectProperty(o);    foreach (string str_property in ls_propertys)    {      if (result.Equals("{"))      {        result = result + str_property;      }      else      {        result = result + "," + str_property + "";      }    }    return result + "}";  }  #endregion  /**     * 把對象列表轉換成json串     * */  public string toJSON(List<object> objlist)  {//覆寫,給懶人一個不寫classname的機會    return toJSON(objlist, string.Empty);  }  public string toJSON(List<object> objlist, string classname)  {    string result = "{";    if (classname.Equals(string.Empty))//如果沒有給定類的名稱,那么自做聰明地安一個    {      object o = objlist[0]      classname = o.GetType().ToString();    }    result += "/"" + classname + "/":[";    bool firstline = true;//處理第一行前面不加","號    foreach (object oo in objlist)    {      if (!firstline)      {        result = result + "," + OneObjectToJSON(oo);      }      else      {        result = result + OneObjectToJSON(oo) + "";        firstline = false;      }    }    return result + "]}";  }}

OK,我們建立一個測試來驗證一下它是否生效。

先建立一個對象定義person.cs

namespace Model{  public class Person  {    public string ID { get; set; }    public string Name { get; set; }    public string Sex { get; set; }  }}

然后建立測試類

我用了一種非常原始的方法生成了對象列表,其實可以從數據庫查詢,怕把事情搞得太復雜。呵呵。

using NUnit.Framework;using System.Collections.Generic;namespace JSon{  [TestFixture]  public class TestObjectToJSON  {    [Test]    public void dotest() {      Model.Person p1 = new Model.Person();      p1.ID = "1";      p1.Name = "p1";      p1.Sex = "s1";      Model.Person p2 = new Model.Person();      p2.ID = "2";      p2.Name = "p2";      p2.Sex = "s2";      Model.Person p3 = new Model.Person();      p3.ID = "3";      p3.Name = "p3";      p3.Sex = "s3";      List<object> lp = new List<object>();      lp.Add(p1);      lp.Add(p2);      lp.Add(p3);      ObjectListToJSON t = new ObjectListToJSON();      string json = t.toJSON(lp, "persons");      System.Console.Write(json);    }  }}

跑一下Nuint,我們想要的json串已經生成了。

以上這篇將List對象列表轉換成JSON格式的類實現方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南投市| 镇宁| 黎平县| 通道| 秀山| 隆回县| 益阳市| 上犹县| 本溪| 瑞金市| 彝良县| 南昌县| 手游| 潢川县| 德化县| 白水县| 廊坊市| 绥德县| 磴口县| 武乡县| 玛沁县| 桦南县| 弋阳县| 皮山县| 阿合奇县| 原阳县| 浠水县| 巴里| 祥云县| 清远市| 西安市| 八宿县| 惠水县| 兰考县| 信阳市| 新营市| 福贡县| 雅江县| 天峻县| 米脂县| 高陵县|