ASP.NET自帶對(duì)象JSON字符串與實(shí)體類的轉(zhuǎn)換
關(guān)于JSON的更多介紹,請(qǐng)各位自行g(shù)oogle了解!如果要我寫(xiě)的話,我也是去Google后copy!嘿嘿,一直以來(lái)很想學(xué)習(xí)json,大量的找資料和寫(xiě)demo,總算有點(diǎn)了解! 切入正題!
還是先封裝一個(gè)類吧! 這個(gè)類網(wǎng)上都可以找到的!有個(gè)這個(gè)類,一切都將變得簡(jiǎn)單了,哈哈。
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Runtime.Serialization.Json; using System.ServiceModel.Web;///記得引用這個(gè)命名空間 using System.IO; using System.Text; /// <summary> /// Summary description for JsonHelper /// </summary> public class JsonHelper { public JsonHelper() { // // TODO: Add constructor logic here // } /// <summary> /// 把對(duì)象序列化 JSON 字符串 /// </summary> /// <typeparam name="T">對(duì)象類型</typeparam> /// <param name="obj">對(duì)象實(shí)體</param> /// <returns>JSON字符串</returns> public static string GetJson<T>(T obj) { //記住 添加引用 System.ServiceModel.Web /** * 如果不添加上面的引用,System.Runtime.Serialization.Json; Json是出不來(lái)的哦 * */ DataContractJsonSerializer json = new DataContractJsonSerializer(typeof(T)); using (MemoryStream ms = new MemoryStream()) { json.WriteObject(ms, obj); string szJson = Encoding.UTF8.GetString(ms.ToArray()); return szJson; } } /// <summary> /// 把JSON字符串還原為對(duì)象 /// </summary> /// <typeparam name="T">對(duì)象類型</typeparam> /// <param name="szJson">JSON字符串</param> /// <returns>對(duì)象實(shí)體</returns> public static T ParseFormJson<T>(string szJson) { T obj = Activator.CreateInstance<T>(); using (MemoryStream ms = new MemoryStream (Encoding.UTF8.GetBytes(szJson))) { DataContractJsonSerializer dcj = new DataContractJsonSerializer(typeof(T)); return (T)dcj.ReadObject(ms); } } }
測(cè)試實(shí)體類:
public class TestData { public TestData() { } public int Id { get; set; } public string Name { get; set; } public string Sex { get; set; } }
測(cè)試頁(yè)面:
<%@ Page Language="C#" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <script runat="server"> protected void Page_Load(object sender, EventArgs e) { string jsonStr = string.Empty; List<TestData> tds = new List<TestData>(); //測(cè)試數(shù)據(jù) for (int i = 1; i < 4; i++) { tds.Add(new TestData() { Id = i, Name = "jinho" + i, Sex = "male" }); } //把一個(gè)list轉(zhuǎn)換為json字符串 jsonStr = JsonHelper.GetJson<List<TestData>>(tds); Response.Write(jsonStr); this.Page.ClientScript.RegisterStartupScript(this.GetType(), "json", "getJson(" + jsonStr + ");", true); } </script> <script type="text/javascript"> function getJson(jsonStr) { //使用eval函數(shù) var json = eval(jsonStr); //因?yàn)樯厦鏋閘ist集合 for (var i = 0; i < json.length; i++) { alert(json[i].Id + "Name:" + json[i].Name); } } </script> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <title></title> </head> <body> <form id="form1" runat="server"> <div> </div> </form> </body> </html>
關(guān)于json字符串轉(zhuǎn)換為實(shí)體請(qǐng)各位自己測(cè)試吧!只要有上面那個(gè)JsonHelper 類,一切都好辦!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ASP.NET技巧:請(qǐng)求網(wǎng)址并解析返回的html
ASP.NET技巧:請(qǐng)求網(wǎng)址并解析返回的html...2006-09-09ASP.NET Core使用自定義驗(yàn)證屬性控制訪問(wèn)權(quán)限詳解
這篇文章主要給大家介紹了關(guān)于ASP.NET Core使用自定義驗(yàn)證屬性控制訪問(wèn)權(quán)限的相關(guān)資料,這是我們?cè)谌粘9ぷ髦薪?jīng)常會(huì)遇到的一個(gè)需求,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-10-10.Net Core實(shí)現(xiàn)圖片文件上傳下載功能
這篇文章主要為大家詳細(xì)介紹了.Net Core實(shí)現(xiàn)圖片文件上傳下載功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06在FireFox/IE下Response中文文件名亂碼問(wèn)題解決方案
只是針對(duì)沒(méi)有空格和IE的情況下使用Response.AppendHeader()如果想在FireFox下輸出沒(méi)有編碼的文件,并且IE下輸出的文件名中空格不為+號(hào),就要多一次判斷了,接下來(lái)將詳細(xì)介紹下感興趣的朋友可以了解下,或許對(duì)你有所幫助2013-02-02ASP.NET一次性對(duì)GridView批量更新多行數(shù)據(jù)
這篇文章介紹了ASP.NET一次性對(duì)GridView批量更新多行數(shù)據(jù)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05如何在不同.net版本實(shí)現(xiàn)單點(diǎn)登錄
經(jīng)過(guò)研究,重寫(xiě)實(shí)現(xiàn)了一個(gè)可以在不同.net版本中實(shí)現(xiàn)單點(diǎn)登錄的簡(jiǎn)單方法?,F(xiàn)在和大家分享一下,不足之處還望見(jiàn)諒2013-07-07.net MVC 連接數(shù)據(jù)本地?cái)?shù)據(jù)庫(kù)三種方法總結(jié)
這篇文章主要介紹了.net MVC 連接數(shù)據(jù)本地?cái)?shù)據(jù)庫(kù)三種方法總結(jié)的相關(guān)資料,這里附有代碼實(shí)例,需要的朋友可以參考下2016-12-12