我正在尝试做一些相当简单的事情,但似乎是一个几乎不可能完成的SharePoint API任务.
我的SharePoint数据结构如下:
-Folder
---子文件夹
--------项目A
--------项目B
--------项目C
--------项目D.
由于某些奇怪的原因,您无法以您期望的分层方式访问文件夹和子文件夹!当我遍历List时,它将返回忽略层次结构的所有项(即它将返回列表中的所有内容).更糟糕的是,为了管理代码中的结构,您不知道项目是否是文件夹.
现在我正在编写自定义对象,以使SharePoint对象模型更有意义,并在我期望的层次结构中对数据进行分组.我计划将我的SharePoint项目映射如下:
public class Folder { public Folder Parent {get; set;} public Folder Root {get; set;} public IList- Items {get; set;} }
有没有人做过类似的事情或者你是如何在SharePoint中管理这个限制的?
如果我开始映射到我的自定义对象模型,是否有任何经验教训和需要注意的事项?
编辑:
我的最终解决方案是从list.RootFolder.SubFolders开始循环遍历文件夹.
var query = from SPList list in Utils.GetList(webRelativeUrl, listName) from SPFolder folder in list.RootFolder.SubFolders where folder.Name.ToLower() != "forms" select new Folder //Custom Object { Name = folder.Name, Children = (from SPFolder subFolder in folder.SubFolders //Further looping of sub folders select new Folder { Name = subFolder.Name, Items = (from SPFile file in subFolder.Files select new Item { //Mapping code omitted } ).ToList() } {) } return query.ToList();
Lars Fastrup.. 5
不,只需使用SPQuery类从单个文件夹中获取项目.此文章解释了如何.
不,只需使用SPQuery类从单个文件夹中获取项目.此文章解释了如何.