下载了官网的 Ext direct 包进行研究,发现服务器端返回结果存在一点小问题。主要问题在返回的结果 result 标记对应的数据是字符串,请看以下官方例子中返回的数据:
{"type":"rpc","tid":2,"action":"Sample","method":"SaveForm","result":"{/"firstName/":/"4/",/"lastName /":/"4/",/"age/":4}"}
|
“ result ”标记对应的是一个字符串,而不是对象,这就需要在处理数据时先要将字符串转换成 JSON 对象才能继续处理。这会造成使用 DirectStore 作为 Grid 数据源时取不到数据的问题。在官网论坛找了一下,有个例子是重写 Ext.data.DirectProxy 的 createCallback 方法实现的,其目的就是在获取到数据后,将 result 中的数据转换为对象再返回数据。以下是重写 createCallback 方法的代码:
|
例子可以到以下地址下载: http://ny504427.bizhostnet.com/Default.aspx
不过笔者的想法是能不能在服务器端解决这个问题。在 Ext.Direct.dll 的源代码中,笔者找到 DirectResponse 类的“ Result ”的定义类型是一个 object ,于是笔者在例子中将客户端调用的方法的返回数据类型修改为 JObject ,但是在执行以下语句的时候会出现错误:
return JsonConvert .SerializeObject(response); |
看来这里需要修改一下,于是笔者将 DirectProcessor 类中的以上这句修改为以下代码:
JObject o = new JObject ( new JProperty ("type" ,response.Type), new JProperty ("tid" ,response.TransactionId), new JProperty ("action" ,response.Action), new JProperty ("method" ,response.Method), new JProperty ("result" ,(JObject )response.Result) ); return o.ToString();
|
其作用就是如果“ Result ”属性中的数据是“ JObject ”对象,程序就重新构造一个 JObject 对象再组合成字符串返回,如果不是就按原方法返回。
在客户端调用方法中只要返回一个 JObject 对象就可以了,例子如下:
[DirectMethod ] public object GetGridDatas() { JArray ja = new JArray (); for (int i = 0; i < 2; i++) { ja.Add(new JObject ( new JProperty ("id" ,i), new JProperty ("title" ,"title" +i.ToString()) )); } JObject o = new JObject ( new JProperty ("results" , 2), new JProperty ("rows" , ja) ); return o; }
|