本文来自的第三章《异步调用Web Service和页面中的类方法》,请同时参考。
3.7.5 数组类型
ASP.NET AJAX异步通讯层能够为数组类型自动生成相应的客户端JavaScript数组,如果数组中的项目为简单类型,那么无需任何额外操作。考虑如下的返回int[]的Web Service方法:
[WebMethod]
public int[] GetIntArray()
{
return new int[] { 1, 2, 3, 4, 5, 6 };
}
通过ASP.NET AJAX异步通讯层调用该Web Service方法之后,返回值在Visual Studio调试器中显示出的结构如图3-27所示。
图3-27服务器端int[]类型在客户端的结构
传递简单类型的数组也非常直观,考虑如下接受一个int[]参数的Web Service方法:
[WebMethod]
public void SendIntArray(int[] intArray)
{
// ......
}
我们可以在客户端构造一个整数数组,然后通过ASP.NET AJAX异步通讯层传递给该方法:
var intArray = [1, 2, 3, 4, 5];
PeopleManagementService.SendIntArray(intArray);
图3-28显示了传入的整数数组在Visual Studio调试器中显示出的结构。
图3-28 客户端的整数JavaScript数组可被自动转换为服务器端int[]类型
如果数组中包含的项目为复杂类型,那么我们仍旧需要为Web Service类添加[GenerateScriptType(typeof([TypeName]))]属性,其中[TypeName]表示该复杂类型的名称。依旧是以前面的Employee类为例,考虑下面这个返回一个Employee[]类型的Web Service方法,注意其中调用了前面小节中给出的GetGenericEmployeeList()方法:
[WebMethod]
public Employee[] GetEmployeeArray()
{
return GetGenericEmployeeList().ToArray();
}
从客户端调用该Web Service方法之后,返回值在Visual Studio调试器中显示出的结构如图3-29所示。
图3-29服务器端Employee[]类型在客户端的结构
为Web Service类添加[GenerateScriptType(typeof(Employee))]属性之后,向服务器端传递Employee[]类型的数组也不难理解。考虑如下接受Employee[]类型的Web Service方法:
[WebMethod]
public void SendEmployeeArray(Employee[] employeeArray)
{
// ......
}
然后用如下JavaScript代码构造一个包含客户端Employee对象的数组,并传递给该SendEmployeeArray()方法:
var employeeArray = new Array();
for (var i = 0; i < 10; ++i) {
var em = new Employee();
em.Id = i;
em.Name = "name " + i;
em.Email = "name" + i + "@some.com";
em.Salary = 1000;
employeeArray.push(em);
}
PeopleManagementService.SendEmployeeArray(employeeArray);
ASP.NET AJAX异步通讯层将自动把这个JavaScript数组转换为服务器端的Employee[]类型。图3-30显示了传入参数在Visual Studio调试器中显示出的结构。
图3-30客户端的Employee数组可被自动转换为服务器端Employee[]类型
如果需要的话,我们还可以将数组类型改为更为泛化的ArrayList。例如对于如下返回的ArrayList的Web Service方法来说,由于其中实际包含的仍是Employee项目,所以客户端将仍会接收到与图3-29中所示相同的Employee数组。
[WebMethod]
public ArrayList GetEmployeeList()
{
ArrayList employeeList = new ArrayList();
for (int i = 0; i < 10; ++i)
{
Employee em = new Employee(
i,
string.Format("name {0}", i),
string.Format("name{0}@some.com", i),
5000
);
employeeList.Add(em);
}
return employeeList;
}