我正在尝试做一些相当简单的事情,但似乎是一个几乎不可能完成的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<Item> Items {get; set;}
}
Run Code Online (Sandbox Code Playgroud)
有没有人做过类似的事情或者你是如何在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();
Run Code Online (Sandbox Code Playgroud)