我有一个问题要找到正确的方法将我的动态数据放入 jQuery jqGrid 可以读取的列表中:
我到现在为止:
[WebMethod]
[System.Web.Script.Services.ScriptMethod(ResponseFormat = System.Web.Script.Services.ResponseFormat.Json)]
public List<DynamicClass> InvokeData(string q)//, out List<dynamic> list)
{
DataSet OutResult = null;
string _function = "ex_medicals";
string[] qSplit = q.Split('&');
_sqlSupporter._ConvertForSending(Convert.ToInt32(qSplit[1]), qSplit[0], _function, out OutResult);
//DataSet _return = _ConvertForSending(1, q, _function);
OutResult.Tables[0].TableName = OutResult.Tables[0].Rows[0]["name"].ToString();
OutResult.Tables[1].TableName = OutResult.Tables[0].Rows[1]["name"].ToString();
DataTable _data = OutResult.Tables["general"];
List<DynamicClass> DynamicClassList = new List<DynamicClass>();
ToObject dyna = new ToObject();
int i = 0;
List<object> myObj = new List<object>();
foreach (DataRow r in _data.Rows)
{
DynamicClass dynamicClass = new DynamicClass();
dyna.ConvertRowToCustomer(r, out dynamicClass);
DynamicClassList.Add(dynamicClass);
}
return DynamicClassList;
}
我想返回这个:
List<Object> Gridist = new List<Object>();
Gridist.AddRange(new Object[]{
new {id="1",name="Medical 1",city="Kiev",instituteTypeId="0"},
new {id="2",name="Medical 2",city="Kherson",instituteTypeId="0"}
});
我的 DynamicClassList ( http://imgur.com/OtPFtAo ) 中已经有所有数据,但是不知道如何以这种特定方式将其放入 Gridist,因为我的 jqGrid 需要这种类型的数据。注意:我需要使用 DynamicClassList 列表中的键和值,因为这两个值都是动态的。
更新:我添加了:
var iSerializer = new System.Web.Script.Serialization.JavaScriptSerializer();
string iJSON = iSerializer.Serialize(dynamicClass.Property.properties);
Gridist.Add(new Object[] { new { iJSON } });
IJson 返回完整的字符串,但是 iJSON 现在看起来像这样并且不是对象: [{"iJSON":"{\"id\":1,\"name\":\"Medical 1\",\"city \":\"基辅\",\"instituteTypeId\":0}"},{"xJSON":"{\"id\":1,\"name\":\"医疗1\",\"城市\":\"基辅\",\"instituteTypeId\":0}"}]
任何帮助将不胜感激。