该死的代码
三聪的博客
posts - 25,comments - 92,views - 64691

      对于习惯使用GridView的人来说,前台页面需要动态添加表格的行数,是一件痛苦的事。GridView处理这种事情相当麻烦,你点击“新增一行”,需要回传到服务器。服务器再把GridView反构造成DataTable, 再给DataTable增加一行之后,绑定到GridView,然后发回客户端...

      能不能简单一点呢?

      

       在使用Ajax数据请求数据,通常都是简单格式,比如String,信息量较少。当然也可以请求回XML,但是XML数据冗余多,取到客户端处理比json麻烦的多。

      能不能简单一点呢? 

 

 

      上面这些问题,如果DataTable与JSON类型可以方便的相互转换,都可以迎刃而解了。

       优点:1)避免不必要的回传;

                2)精简异步请求数据的大小 ;

                3)解决数据量较大时,数据发送与接收繁琐的问题。

 

      既然好处这么多,我们上代码吧。

前台代码: 

复制代码
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    
<title></title>

    
<script type="text/javascript" src="js/jquery-1.4.2.min.js"></script>

    
<script type="text/javascript" src="js/json2.js"></script>

    
<script type="text/javascript">
        
//onload
        $(function() {
            
//点击botton1
            $("#botton1").click(function() {
                
var url = "default.aspx?ajax=1";
                
var dtb = generateDtb();
                
//序列化对象
                var postdata = JSON.stringify(dtb);
                
//异步请求
                $.post(url, { json: postdata }, function(json) {
                    createTable(json);
                }, "json")

            });
        });

        
//生成DataTable对象
        function generateDtb() {
            
var dtb = new Array();
            
for (var i = 0; i < 10; i++) {
                
var row = new Object();
                row.col1 = i;
                row.col2 = i % 2 == 0 ? true : false;
                row.col3 = i + "he\nll\"ow";
                dtb.push(row);
            }
            return dtb;
        }

        //显示Json中的数据
        function createTable(json) {
            var table = $("<table border='1'></table>");
            for (var i = 0; i < json.length; i++) {
                o1 = json[i];
                
var row = $("<tr></tr>");
                
for (key in o1) {
                    
var td = $("<td></td>");
                    td.text(o1[key].toString());
                    td.appendTo(row);
                }
                row.appendTo(table);
            }
            table.appendTo($("#back"));
        }
       
    
</script>

</head>
<body>
    
<form id="form1" runat="server">
    
<div>
        
<input id="botton1" type="button" value="button" />
        
<div id="back">
        
</div>
    
</div>
    
</form>
</body>
</html>
复制代码

 

 

后台代码:

 /// <summary>

复制代码
    /// 页面加载时
    
/// </summary>
    
/// <param name="sender"></param>
    
/// <param name="e"></param>
    protected void Page_Load(object sender, EventArgs e)
    {
        
//判断是否异步请求
        if (Request.QueryString["ajax"== "1")
        {
            ProcessRequest();
        }
    }

    
/// <summary>
    
/// 处理异步请求
    
/// </summary>
    private void ProcessRequest()
    {
        Response.ContentType = "text/html";

        
string json = Request.Form["json"];
        
//反序列化DataTable
        DataTable newdtb = Json2Dtb(json);

        
//序列化DataTable为JSON
        string back = Dtb2Json(newdtb);
        Response.Write(back);
        Response.End();
    }

    
/// <summary>
    
/// DataTable转Json
    
/// </summary>
    
/// <param name="dtb"></param>
    
/// <returns></returns>
    private string Dtb2Json(DataTable dtb)
    {
        JavaScriptSerializer jss = new JavaScriptSerializer();
        ArrayList dic = new ArrayList();

        
foreach (DataRow row in dtb.Rows)
        {
            Dictionary<stringobject> drow = new Dictionary<stringobject>();
            
foreach (DataColumn col in dtb.Columns)
            {
                drow.Add(col.ColumnName, row[col.ColumnName]);
            }
            dic.Add(drow);
        }

        
return jss.Serialize(dic);
    }

    
/// <summary>
    
/// Json转DataTable
    
/// </summary>
    
/// <param name="json"></param>
    
/// <returns></returns>
    private DataTable Json2Dtb(string json)
    {
        JavaScriptSerializer jss = new JavaScriptSerializer();
        ArrayList dic = jss.Deserialize<ArrayList>(json);
        DataTable dtb = new DataTable();

        
if (dic.Count > 0)
        {
            
foreach (Dictionary<stringobject> drow in dic)
            {
                
if (dtb.Columns.Count == 0)
                {
                    
foreach (string key in drow.Keys)
                    {
                        dtb.Columns.Add(key, drow[key].GetType());
                    }
                }

                DataRow row = dtb.NewRow();
                
foreach (string key in drow.Keys)
                {

                    row[key] = drow[key];
                }
                dtb.Rows.Add(row);
            }
        }
        
return dtb;
    }

 

复制代码


再附一个下载文件,觉得有用的可以下载看看 

json.zip 

posted on   三聪  阅读(4352)  评论(5编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
< 2010年9月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 1 2
3 4 5 6 7 8 9

作者:gateluck
出处:http://gateluck.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
点击右上角即可分享
微信分享提示