(二)列表(SPList)
列表是SharePoint中最为重要的数据容器,我们一般保存在SharePoint中的所有数据,都是保存在列表中(文档库也是一种列表),因此列表对象在SharePoint的开发中是非常重要的对象之一。在SharePoint中,列表对象使用SPList表示,列表的集合使用SPListCollection表示。
如果实在难以理解SharePoint列表是怎么一回事的话,可以设想如下这种其实不准确的比喻,与传统的数据类型相比较,有如下的对应关系:列表(SPList)相当于数据表(DataTable);视图(SPView)相当于数据视图(DataView);字段(SPField)相当于数据栏(DataColumn);列表条目(SPListItem)相当于数据行(DataRow)。
技巧提示: 在创建一个列表之后,我们会注意到列表的根目录和列表名称可能存在着一定的关系,读者可以尝试着使用英文、中文、中英文混杂的名称创建一些列表,并观察列表路径中的规律。对于全中文列表名称而言,列表的路径可能会是“Lists/List”、“Lists/List1”、“Lists/List2”这样一些没有实际含意的Url。在实际应用中创建中文名称列表的时候,可以先使用一个有意义的英文名称创建列表(比如“Contacts”),再将其标题修改成中文(比如“联系人”)。 |
1、列表的获取
列表的获取有如下若干种方式:
(1) 使用SPWeb的Lists属性获取网站中所有列表的集合(SPListCollection),之后使用索引器获取特定的某个列表:
(2) 使用SPWeb的GetList方法,根据列表相对服务器的路径获取;
(3) 使用SPWeb的GetListFromUrl,根据列表的一些视图页面的相对网站的路径(也可以使用相对服务器的路径)获取列表;
(4) 使用SPWeb的GetListsOfType方法,获取某一特定基类型(见后文)的所有列表。
获取到列表集合(SPListCollection)后,通过其TryGetList方法,根据列表的标题尝试获取列表。该方法是SharePoint 2010中新增加的方法,之前最常用的是使用字符串索引器的方式根据列表名称来获取列表对象,但如果列表名称并不存在的话,则会抛出一个异常。与之前的获取方法相比,使用TryGetList方法,当列表名称不存在的时候,会返回null,更加人性化。
例如,如下的程序获取了网站中一个名叫“Chapters”的列表:
1: using(SPSite site = new SPSite("http://sp2010/book"))
2: {
3: using(SPWeb web = site.OpenWeb())
4: {
5: SPList chptList = web.Lists.TryGetList("Chapters");
6: if(chptList != null)
7: {
8: // use the list
9: }
10: }
11: }
2、列表的基类型(BaseType)和列表模板(BaseTemplate)
这是两个比较容易混淆的属性和概念,但是这两个概念在SharePoint的跨网站跨列表查询、事件处理程序、网站功能(Feature)中是非常重要的,因此在这里做一个简要的说明。
列表的基类型指的是列表的基本类型,不同基本类型的列表之间在底层结构上有着较大的差异,SharePoint内置有5种基本类型的列表(参考SPBaseType枚举类型):
由上述分类可以看出,列表的基类型定义了列表的基本结构和大体功能,而列表模板则更具体地定义了一个列表的具体结构、字段、视图等信息,我们在列表创建页面中所看到的每一个链接,基本上都是一个个不同的列表模板,当然我们也可以通过将列表另存为模板的方式,将一个配置好字段、视图信息的列表保存为自定义的列表模板。
SharePoint内置了很多种列表模板,每种内置的列表模板都有一个整型的ID,例如通知列表的模板ID为104、文档库模板的ID为101。这些内置列表模板和ID值可以参考SDK中的SPListTemplateType枚举类型。
3、列表的常用属性
SPList的常用属性如下:
名称 |
类型 |
说明 |
BaseTemplate |
SPListTemplateType |
列表模板 |
BaseType |
SPBaseType |
列表的基类型 |
DefaultView |
SPView |
列表的默认视图 |
RootFolder |
SPFolder |
列表的根文件夹 |
Title |
string |
列表的标题 |
Items |
SPListItemCollection |
列表中的所有条目(非文件夹条目) |
Folders |
SPListItemCollection |
列表中的所有文件夹条目,详见后文解释 |
Fields |
SPFieldCollection |
列表中的所有字段 |
Forms |
SPFormCollection |
列表中的表单(如新建、编辑、查看等) |
Views |
SPViewCollection |
列表中的所有视图 |
例如,如下的程序列出了网站中的所有列表,并打印出其列表的标题:
1: using(SPSite site = new SPSite("http://sp2010/book"))
2: {
3: using(SPWeb web = site.OpenWeb())
4: {
5: foreach(SPList list in web.Lists)
6: Console.WriteLine(list.Title);
7: }
8: }