0

我正在尝试为我的系统使用 jquery DataTables 插件,使用 web 服务通过 ajax 调用填充数据。

我需要从网络服务返回的是这样的列表:List<List<string>>;

我有大约 120 个不同的域类被它用作核心数据对象,所以我需要某种系统,我可以从不同的域类中获取数据并List<List<string>>以某种自动的方式将它们转换为。

我获取数据的方式是这样的(示例代码):

List<Core.Room> coreDataList = Core.GetRoomsInHotel(int hotelID);

我一直在研究 DynamicLinq 和 System.Reflection,但一无所获:(


更新:

我需要从 web 服务返回的是一个这样的数组:

[
    ["data-col-1","data-col-2","data-col-3","data-col-4"],
    ["data-col-1","data-col-2","data-col-3","data-col-4"],
    ["data-col-1","data-col-2","data-col-3","data-col-4"]
]

为了填充这个数组,我有大约 120 个具有不同属性的域类的不同列表,我需要动态访问每个属性的这些属性:

对于一个房间,基于如下所示的对象:

public class Room {
    public int ID { get; set; }
    public string Name { get; set; }
    public string Code { get; set; }
    public string LongName { get; set; }
}
[
    ["ID", "Double","DBL"],
    ["ID", "Single","SNG"],
    ["ID", "Suite","SUI"]
]

对于酒店:

public class Hotel {
    public int ID { get; set; }
    public string Name { get; set; }
    public string Address { get; set; }
    public int RoomCount { get; set; }
    public int FloorCount { get; set; }
}
[
    ["1","Plaza","153","12"],
    ["2","Astoria","568","25"]
]

我有一个带有列表配置的 XML 文件:

<list id="29">
  <readable_name>Hotels - Roomtypes - List all roomtypes in system</readable_name>
  <no_data_message>No roomtypes found</no_data_message>
  <cols>
    <col width="0" visible="false" datafield="ID" type="key" headertext="ID" />
    <col width="70" visible="true" datafield="Name" type="string" headertext="Name" />
    <col width="30" visible="true" datafield="Type" type="string" headertext="Type" />
  </cols>
</list>

因此,我根据要加载的列表从 XML 文件中提取配置。我根据列表 ID 调用数据存储,并获取我想要的任何域类(房间/酒店)的列表。我遍历返回的列表并生成某种数组,以便可以填充页面上的列表。

我希望这能澄清一些事情......

4

1 回答 1

2
List<Core.Room> coreDataList = Core.GetRoomsInHotel(int hotelID); 
List<string> coreDataStrList = coreDataList
                                .Select(room => room.ToString())
                                .ToList();

除此之外,我们将需要有关您的代码的更多信息。

更新:

List<string> ToStringList<T>(this IEnumerable<T> list)
{
    list.Select(obj => obj.ToString()).ToList();
}

List<Core.Room> coreRoomList = ... 
List<Core.Hotel> coreHotelList = ... 

List<List<string>> ListofLists = new List<List<string>> ();

ListofLists.Add(coreRoomList.ToStringList());
ListofLists.Add(coreHotelList.ToStringList());

(如果你一次给我们多一行代码,那会很有帮助。这 120 个列表是否以某种方式分组?它们有共同的基础吗?

于 2010-08-18T14:30:22.553 回答