有什么框架中带有DataTable To Json的功能?
现在在网上搜,只能搜到热心网友自己实现的DataTable To Json的方法。

解决方案 »

  1.   

    你可以把这个方法放到你的工程里啊。public static string DataTableToJson(string jsonName, System.Data.DataTable dt)
            {
                System.Text.StringBuilder Json = new System.Text.StringBuilder();
                Json.Append("{\"" + jsonName + "\":[");
                if (dt.Rows.Count > 0)
                {
                    for (int i = 0; i < dt.Rows.Count; i++)
                    {
                        Json.Append("{");
                        for (int j = 0; j < dt.Columns.Count; j++)
                        {
                            Json.Append("\"" + dt.Columns[j].ColumnName.ToString() + "\":\"" + dt.Rows[i][j].ToString() + "\"");
                            if (j < dt.Columns.Count - 1)
                            {
                                Json.Append(",");
                            }
                        }
                        Json.Append("}");
                        if (i < dt.Rows.Count - 1)
                        {
                            Json.Append(",");
                        }
                    }
                }
                Json.Append("]}");
                return Json.ToString();
            }
            public static string ObjectToJson<T>(string jsonName, IList<T> IL)
            {
                System.Text.StringBuilder Json = new System.Text.StringBuilder();
                Json.Append("{\"" + jsonName + "\":[");
                if (IL.Count > 0)
                {
                    for (int i = 0; i < IL.Count; i++)
                    {
                        T obj = Activator.CreateInstance<T>();
                        Type type = obj.GetType();
                        System.Reflection.PropertyInfo[] pis = type.GetProperties();
                        Json.Append("{");
                        for (int j = 0; j < pis.Length; j++)
                        {
                            Json.Append("\"" + pis[j].Name.ToString() + "\":\"" + pis[j].GetValue(IL[i], null) + "\"");
                            if (j < pis.Length - 1)
                            {
                                Json.Append(",");
                            }
                        }
                        Json.Append("}");
                        if (i < IL.Count - 1)
                        {
                            Json.Append(",");
                        }
                    }
                }
                Json.Append("]}");
                return Json.ToString();
            }
      

  2.   

    Newtonsoft.Json 也可以参考
      

  3.   

    Json.Net 呀。http://json.codeplex.com/
      

  4.   

    json
    {keyname:value,……}发挥一下吧,其实就是拼接,看谁的郊率好,而且要处理好无效字符,转义字符