亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

通過Jquery的Ajax方法讀取將table轉換為Json

2019-11-20 15:00:09
字體:
來源:轉載
供稿:網友
1. 創建Users表
復制代碼 代碼如下:

create table Users
(
UserId int identity(1,1) primary key,
UserName varchar(20)
)

insert into Users values('Bradley')
insert into Users values('Dan')

復制代碼 代碼如下:

create table Users
(
UserId int identity(1,1) primary key,
UserName varchar(20)
)

insert into Users values('Bradley')
insert into Users values('Dan')

2. 創建JsonHelper類
復制代碼 代碼如下:

public class JsonHelper
{
#region 序列化和反序列化
// 序列化
public static string JsonSerializer<T>(T t)
{
// 使用 DataContractJsonSerializer 將 T 對象序列化為內存流。
DataContractJsonSerializer jsonSerializer = new DataContractJsonSerializer(typeof (T));
MemoryStream ms = new MemoryStream();
// 使用 WriteObject 方法將 JSON 數據寫入到流中。
jsonSerializer.WriteObject(ms, t);
// 流轉字符串
string jsonString = Encoding.UTF8.GetString(ms.ToArray());
ms.Close();
//替換Json的Date字符串
string p = @"http:///Date/((/d+)/+/d+/)///";
MatchEvaluator matchEvaluator = new MatchEvaluator(ConvertJsonDateToDateString);
Regex reg = new Regex(p);
jsonString = reg.Replace(jsonString, matchEvaluator);
return jsonString;
}
public static T JsonDeserialize<T>(string jsonString)
{
//將"yyyy-MM-dd HH:mm:ss"格式的字符串轉為"http://Date(1294499956278+0800)//"格式
string p = @"/d{4}-/d{2}-/d{2}/s/d{2}:/d{2}:/d{2}";
MatchEvaluator matchEvaluator = new MatchEvaluator(ConvertDateStringToJsonDate);
Regex reg = new Regex(p);
jsonString = reg.Replace(jsonString, matchEvaluator);
DataContractJsonSerializer jsonSerializer=new DataContractJsonSerializer(typeof(T));
// 字符串轉流
MemoryStream ms=new MemoryStream(Encoding.UTF8.GetBytes(jsonString));
// 通過使用 DataContractJsonSerializer 的 ReadObject 方法,將 JSON 編碼數據反序列化為T
T obj = (T) jsonSerializer.ReadObject(ms);
return obj;
}
public static string ConvertJsonDateToDateString(Match match)
{
string result = string.Empty;
DateTime dateTime=new DateTime(1970,1,1);
dateTime = dateTime.AddMilliseconds(long.Parse(match.Groups[1].Value));
dateTime = dateTime.ToLocalTime();
result = dateTime.ToString("yyyy-MM-dd HH:mm:ss");
return result;
}
private static string ConvertDateStringToJsonDate(Match m)
{
string result = string.Empty;
DateTime dt = DateTime.Parse(m.Groups[0].Value);
dt = dt.ToUniversalTime();
TimeSpan ts = dt - DateTime.Parse("1970-01-01");
result = string.Format("http:///Date({0}+0800)///",ts.TotalMilliseconds);
return result;
}
#endregion

// 對象轉換為Json
public static string ObjectToJson(object obj)
{
JavaScriptSerializer js=new JavaScriptSerializer();
try
{
return js.Serialize(obj);
}
catch (Exception exception)
{

throw new Exception(exception.Message);
}
}
// 數據表轉化為集合
public static List<Dictionary<string,object>> DataTableToList(DataTable dt)
{
List<Dictionary<string ,object>> list=new List<Dictionary<string, object>>();
foreach (DataRow dataRow in dt.Rows)
{
Dictionary<string,object> dic=new Dictionary<string, object>();
foreach (DataColumn dc in dt.Columns)
{
dic.Add(dc.ColumnName,dataRow[dc.ColumnName]);
}
list.Add(dic);
}
return list;
}
// 表轉換為Json
public static string DataTableToJson(DataTable dt)
{
return ObjectToJson(DataTableToList(dt));
}
}

復制代碼 代碼如下:

public class JsonHelper
{
#region 序列化和反序列化
// 序列化
public static string JsonSerializer<T>(T t)
{
// 使用 DataContractJsonSerializer 將 T 對象序列化為內存流。
DataContractJsonSerializer jsonSerializer = new DataContractJsonSerializer(typeof (T));
MemoryStream ms = new MemoryStream();
// 使用 WriteObject 方法將 JSON 數據寫入到流中。
jsonSerializer.WriteObject(ms, t);
// 流轉字符串
string jsonString = Encoding.UTF8.GetString(ms.ToArray());
ms.Close();
//替換Json的Date字符串
string p = @"http:///Date/((/d+)/+/d+/)///";
MatchEvaluator matchEvaluator = new MatchEvaluator(ConvertJsonDateToDateString);
Regex reg = new Regex(p);
jsonString = reg.Replace(jsonString, matchEvaluator);
return jsonString;
}
public static T JsonDeserialize<T>(string jsonString)
{
//將"yyyy-MM-dd HH:mm:ss"格式的字符串轉為"http://Date(1294499956278+0800)//"格式
string p = @"/d{4}-/d{2}-/d{2}/s/d{2}:/d{2}:/d{2}";
MatchEvaluator matchEvaluator = new MatchEvaluator(ConvertDateStringToJsonDate);
Regex reg = new Regex(p);
jsonString = reg.Replace(jsonString, matchEvaluator);
DataContractJsonSerializer jsonSerializer=new DataContractJsonSerializer(typeof(T));
// 字符串轉流
MemoryStream ms=new MemoryStream(Encoding.UTF8.GetBytes(jsonString));
// 通過使用 DataContractJsonSerializer 的 ReadObject 方法,將 JSON 編碼數據反序列化為T
T obj = (T) jsonSerializer.ReadObject(ms);
return obj;
}
public static string ConvertJsonDateToDateString(Match match)
{
string result = string.Empty;
DateTime dateTime=new DateTime(1970,1,1);
dateTime = dateTime.AddMilliseconds(long.Parse(match.Groups[1].Value));
dateTime = dateTime.ToLocalTime();
result = dateTime.ToString("yyyy-MM-dd HH:mm:ss");
return result;
}
private static string ConvertDateStringToJsonDate(Match m)
{
string result = string.Empty;
DateTime dt = DateTime.Parse(m.Groups[0].Value);
dt = dt.ToUniversalTime();
TimeSpan ts = dt - DateTime.Parse("1970-01-01");
result = string.Format("http:///Date({0}+0800)///",ts.TotalMilliseconds);
return result;
}
#endregion

// 對象轉換為Json
public static string ObjectToJson(object obj)
{
JavaScriptSerializer js=new JavaScriptSerializer();
try
{
return js.Serialize(obj);
}
catch (Exception exception)
{

throw new Exception(exception.Message);
}
}
// 數據表轉化為集合
public static List<Dictionary<string,object>> DataTableToList(DataTable dt)
{
List<Dictionary<string ,object>> list=new List<Dictionary<string, object>>();
foreach (DataRow dataRow in dt.Rows)
{
Dictionary<string,object> dic=new Dictionary<string, object>();
foreach (DataColumn dc in dt.Columns)
{
dic.Add(dc.ColumnName,dataRow[dc.ColumnName]);
}
list.Add(dic);
}
return list;
}
// 表轉換為Json
public static string DataTableToJson(DataTable dt)
{
return ObjectToJson(DataTableToList(dt));
}
}

3. 添加ashx代碼文件
復制代碼 代碼如下:

public class GetData : IHttpHandler
{

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
if (context.Request["action"]=="display")
{
context.Response.Write(JsonHelper.DataTableToJson(GetAllUsers()));
}
}

static SqlConnection conn = new SqlConnection("server=.;database=Test;uid=sa;pwd=123456");
public static DataTable GetAllUsers()
{
string sql = "select * from users";
SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
DataTable dt = new DataTable();
adapter.Fill(dt);
return dt;
}
public bool IsReusable
{
get
{
return false;
}
}
}

復制代碼 代碼如下:

public class GetData : IHttpHandler
{

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
if (context.Request["action"]=="display")
{
context.Response.Write(JsonHelper.DataTableToJson(GetAllUsers()));
}
}

static SqlConnection conn = new SqlConnection("server=.;database=Test;uid=sa;pwd=123456");
public static DataTable GetAllUsers()
{
string sql = "select * from users";
SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
DataTable dt = new DataTable();
adapter.Fill(dt);
return dt;
}
public bool IsReusable
{
get
{
return false;
}
}
}

4. 前端調用
復制代碼 代碼如下:

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title></title>
<script src="js/jquery-1.6.js" type="text/javascript"></script>
<script type="text/javascript">
$(function() {
var options = {
type: 'post',
url: "/GetData.ashx",
dataType: "json",
data: { action: "display" },
success: function(data) {
var html = "<table border='2px' style='text-align:center;border-style:solid;border-width:2px;border-color:#00ff00;'><tr><td>UserId</td><td>UserName</td></tr>";
$.each(data, function(i, result) {
html += "<tr><td>" + result["UserId"] + "</td><td>" + result["UserName"] + "</td></tr>";
})
html += "</table>";
$("#divData").html(html);
}
};
$.ajax(options);
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="divData">

</div>
</form>
</body>
</html>

復制代碼 代碼如下:

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title></title>
<script src="js/jquery-1.6.js" type="text/javascript"></script>
<script type="text/javascript">
$(function() {
var options = {
type: 'post',
url: "/GetData.ashx",
dataType: "json",
data: { action: "display" },
success: function(data) {
var html = "<table border='2px' style='text-align:center;border-style:solid;border-width:2px;border-color:#00ff00;'><tr><td>UserId</td><td>UserName</td></tr>";
$.each(data, function(i, result) {
html += "<tr><td>" + result["UserId"] + "</td><td>" + result["UserName"] + "</td></tr>";
})
html += "</table>";
$("#divData").html(html);
}
};
$.ajax(options);
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="divData">

</div>
</form>
</body>
</html>

5. 效果圖
 
6. 同樣可以通過getJSON方法讀取數據
復制代碼 代碼如下:


$.getJSON("/GetData.ashx",{ action: "display" },function(data) {
var html = "<table border='2px' style='text-align:center;border-style:solid;border-width:2px;border-color:#00ff00;'><tr><td>UserId</td><td>UserName</td></tr>";
$.each(data, function(i, result) {
html += "<tr><td>" + result["UserId"] + "</td><td>" + result["UserName"] + "</td></tr>";
})
html += "</table>";
$("#divData").html(html);
})

復制代碼 代碼如下:

$.getJSON("/GetData.ashx",{ action: "display" },function(data) {
var html = "<table border='2px' style='text-align:center;border-style:solid;border-width:2px;border-color:#00ff00;'><tr><td>UserId</td><td>UserName</td></tr>";
$.each(data, function(i, result) {
html += "<tr><td>" + result["UserId"] + "</td><td>" + result["UserName"] + "</td></tr>";
})
html += "</table>";
$("#divData").html(html);
})
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美丝袜美女中出在线| 欧美性xxxxx极品| 国产精品99久久久久久白浆小说| 78色国产精品| 欧美日韩精品在线| 7777kkkk成人观看| 91久久久国产精品| 疯狂蹂躏欧美一区二区精品| 国产精品亚洲自拍| 亚洲精品久久久久久下一站| 久久久久久久久久久久久久久久久久av| 免费99精品国产自在在线| 日韩第一页在线| 精品国偷自产在线视频99| 日韩最新在线视频| 国产精品91久久| 欧美成人三级视频网站| 久久免费国产视频| 欧美性xxxx极品高清hd直播| 国产精品国产三级国产专播精品人| 夜夜嗨av色综合久久久综合网| 亚洲精品av在线| 久久综合伊人77777尤物| 亚洲在线观看视频| 成人乱人伦精品视频在线观看| 色与欲影视天天看综合网| 久久精品久久久久久| 国产乱肥老妇国产一区二| 亚洲欧洲视频在线| 成人性教育视频在线观看| 国产999精品久久久| 欧美精品在线极品| 国产成人精品免费久久久久| 欧美成年人在线观看| 97精品国产aⅴ7777| 欧美精品videofree1080p| 日韩美女在线观看一区| 最近2019中文字幕大全第二页| 91视频-88av| 久久99久国产精品黄毛片入口| 亚洲精品久久久久久久久| 91在线视频成人| 亚洲精品视频在线观看视频| 成人免费观看a| 亚洲福利视频久久| 尤物yw午夜国产精品视频| 日韩视频永久免费观看| 亚洲综合色激情五月| 亚洲欧美在线看| 91精品久久久久久久久久久久久| www.亚洲男人天堂| 色噜噜狠狠狠综合曰曰曰| 亚洲图片欧美日产| 亚洲欧洲日韩国产| 欧美成人午夜视频| 国产精品色午夜在线观看| 大胆人体色综合| 亚洲影院在线看| 91久久精品在线| 日本成人激情视频| 久久久久久久久电影| 国产一区视频在线| 欧美日韩激情美女| 成人黄色片网站| 4438全国亚洲精品在线观看视频| 亚洲欧美中文字幕在线一区| 欧美高清电影在线看| 91探花福利精品国产自产在线| 丝袜美腿亚洲一区二区| 久久久精品美女| 欧美视频中文在线看| 国产精品中文在线| 久久亚洲精品网站| 亚洲欧美精品一区| 色悠久久久久综合先锋影音下载| 成人在线播放av| 狠狠躁夜夜躁人人爽天天天天97| 日韩国产高清污视频在线观看| 精品视频—区二区三区免费| 欧美国产中文字幕| 精品亚洲一区二区三区在线观看| 国产97色在线|日韩| xvideos国产精品| 色播久久人人爽人人爽人人片视av| 57pao成人国产永久免费| 国产丝袜精品视频| 国产精品视频白浆免费视频| 亚洲欧洲在线视频| 精品人伦一区二区三区蜜桃免费| 中文字幕日韩综合av| 国产网站欧美日韩免费精品在线观看| 国产精品日韩欧美大师| 亚洲精品欧美日韩专区| 亚洲人成在线免费观看| 亚洲欧美色婷婷| 日本中文字幕久久看| 欧美国产高跟鞋裸体秀xxxhd| 国产精品稀缺呦系列在线| 国外色69视频在线观看| 欧美日韩色婷婷| 日韩av成人在线观看| 性日韩欧美在线视频| 国产精品电影网站| 97国产精品视频| 亚洲sss综合天堂久久| 日韩精品视频在线观看网址| 日韩一区在线视频| 精品福利在线看| 国产视频精品一区二区三区| 国产精品嫩草影院久久久| 欧美在线视频导航| 国产欧美一区二区三区四区| 亚洲欧洲一区二区三区在线观看| 欧美久久精品一级黑人c片| 在线午夜精品自拍| 一区二区三区四区在线观看视频| 国产精品久久网| 91精品久久久久久久| 国产一区二区成人| 亚洲欧美日韩在线高清直播| 欧美成人午夜剧场免费观看| 日本91av在线播放| 久久香蕉国产线看观看网| 亚洲精品福利在线| 亚洲天堂一区二区三区| 国产主播欧美精品| 久久青草福利网站| 中文日韩电影网站| 欧美一区二区大胆人体摄影专业网站| 久久精品国产亚洲精品| 中文字幕久久久av一区| 久久成人18免费网站| 亚洲美女av在线播放| 久久99视频精品| 久久99久久99精品中文字幕| 欧美性理论片在线观看片免费| 亚洲精品综合精品自拍| 一区二区成人av| 中文字幕国产精品| 亚洲精品免费av| 日韩激情av在线播放| 欧美性xxxx极品hd欧美风情| 91精品国产综合久久男男| 日韩欧美在线一区| 中文字幕日韩在线视频| 久久久久99精品久久久久| 欧美性视频在线| 国产亚洲精品久久久久动| 草民午夜欧美限制a级福利片| 福利二区91精品bt7086| 欧美亚洲视频在线看网址| 性欧美办公室18xxxxhd| 亚洲电影天堂av| 一个人www欧美| 国产精品美女呻吟| 久久精品99久久久久久久久| 亚洲国产一区二区三区四区| 日韩av有码在线| 欧美精品videosex极品1| 中日韩美女免费视频网址在线观看| 日本一区二区在线免费播放| 国产精品福利久久久| 国产人妖伪娘一区91| 欧美成人黑人xx视频免费观看|