我应该创建自己的对象模型来处理复杂的 Sharepoint 对象吗?

2024-04-21

我正在尝试做一些相当简单的事情,但使用 SharePoint API 似乎是一项几乎不可能完成的任务。

我的 SharePoint 数据结构如下:

-Folder
--- 子文件夹
--------项目A
--------B项
--------C项
--------D项

由于某些奇怪的原因,您无法以您期望的分层方式访问文件夹和子文件夹!当我迭代列表时,它将返回所有项目,忽略层次结构(即,它将返回列表中的所有内容)。更糟糕的是,您甚至不知道该项目是否是文件夹,以便管理代码中的结构。

现在,我正在编写自定义对象,以使 SharePoint 对象模型更有意义,并按我期望的层次结构对数据进行分组。我计划将我的 SharePoint 项目映射如下:

public class Folder
{
    public Folder Parent {get; set;}
    public Folder Root {get; set;}
    public IList<Item> Items {get; set;}
}

有没有人做过类似的事情,或者您如何在 SharePoint 中管理此限制?

如果我开始映射到自定义对象模型,是否有任何经验教训和需要注意的事项?

EDIT:

我的最终解决方案是从 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();

不,只需使用SPQuery http://www.u2u.info/Blogs/Patrick/Lists/Posts/Post.aspx?ID=1765类从单个文件夹中获取项目。这article http://www.u2u.info/Blogs/Patrick/Lists/Posts/Post.aspx?ID=1765解释了如何。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

我应该创建自己的对象模型来处理复杂的 Sharepoint 对象吗? 的相关文章

随机推荐