先上代码,再指出要注意的地方,
<script type="text/javascript" src="js/jquery/jquery.easyui.min.js"></script>
<script type="text/javascript" src="js/locale/easyui-lang-zh_CN.js"></script>
<script type="text/javascript">
$(function () {
$('#tabList').datagrid({
iconCls: 'icon-forward',
border: true,
rownumbers: true,
striped: true,
pagination: true,
singleSelect: true,
url: "WebService.asmx/GetGrid",
idField: 'id',
columns: [[
{ title: '用户ID', field: 'id', sortable: true },
{ field: 'name', title: '用户名称', sortable: true }
]],
pagination: true,
rownumbers: true
});
});
</script>
websercie代码
#region
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Script.Services;
using System.Data.SqlClient;
using System.Data;
using System.Text;
using System.Configuration;
using System.Runtime.Serialization;
using System.Xml.Serialization;
using System.Web.Script.Serialization;
using System.ServiceModel.Web;
[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string GetGrid()
{
/*
List<Person> UserList = new List<Person>();
UserList.Add(new Person("a",2));
UserList.Add(new Person("ab", 1));
UserList.Add(new Person("dd", 3));
return UserList;
*/
Person[] plist = new Person[2];
plist[0] = new Person();
plist[0].name = "zwm";
plist[0].id = 1;
plist[1] = new Person();
plist[1].name = "zwb";
plist[1].id = 2;
return "{\"total\":2,\"rows\":" + new JavaScriptSerializer().Serialize(plist) + "}";
}
现在说要注意的问题了,直接这样调websercie是显示不出来的,任你再怎么设置JSON 格式什么的,返回给客户端的一直是一段XML字符串,,,但是
下面这段代码却能返回成功,
$(function () {
$.ajax({
url: 'WebService.asmx/GetGrid', // WebService的地址 + 要调用的方法名
data: "{}", // 要发送的参数,JSON格式的字符串 '{"name":"admin", "age":30}',这些参数会被 CreatePerson(string name, int age)接收,注意格式要严格
type: 'post', // 这个你懂得
dataType: 'json', // 期望服务器端返回的数据格式
contentType: 'application/json; charset=utf-8', // 发送给服务器端的格式
success: function (data) {
data = (data && data.d) ? data.d : data;
// 这样写是为了兼容IIS7(以后再细说),data={"name":"admin", "age":30},注意在这里data是对象而不是字符串,可以这样使用:alert(data.name);
},
complete: function (data) {
data = (data && data.d) ? data.d : data;
},
error: function (exception) {
alert(exception);
}
});
});
这就郁闷了,,,,,搜索了很多,就是没找到满意的答案,我就想,这个上面的能成功,为什么,绑定GRID就不能成功,他应该也是掉AJAX方法啊,
就去看easyui.min.js的代码,跟踪,结果,发现他返回的字符串,不是JSON对象,那怎么办啊,只能改这个脚本啦,把获取出来的Data.d 再转换成JSON对象,就可以了,
把这个源代码改一点点,就可以出来了,搞了一下午,都记录在这里,