我有一个从存储过程构建的菜单,它返回一个文件夹层次结构。该过程返回FolderID,Name和ParentID。在我的菜单资源库中,我在文件夹列表上使用了ForEach()来添加与父文件夹关联的每个子文件夹。使用Linq删除同一对象中的孩子的父母
它看起来像这样:
folders = await _dbcontext.MenuFolders.FromSql("EXEC UserMenuFolders @p0", UserID)
.Select(x => new MenuFolder
{
FolderID = x.FolderID,
FolderName = x.FolderName,
SortOrder = x.SortOrder,
SubofID = x.SubofID
})
.ToListAsync();
folders.ForEach(x => x.SubFolders = folders
.Where(y => y.SubofID == x.FolderID)
.OrderBy(y => y.SortOrder)
.ToList());
这给了我一个对象,它看起来有点像:
"Folder 1": {
"Sub Folder 1": [
"SubFolder 1.1",
"SubFolder 1.2"
],
"Sub Folder 2": [
"SubFolder 2.1",
"SubFolder 2.2"
]
},
"Folder 2": {
//Other sub Folders
},
"SubFolder 1":{},
"SubFolder 1.1":{},
"SubFolder 1.2": {}
你可以看到,子文件夹都在那里两次,因为初始查询得到所有文件夹。我如何从列表中删除子文件夹的文件夹?另外,我很想看看是否有更高效的方法来创建这个菜单结构,但请记住我必须使用存储过程,因为授权逻辑已经在那里建立了。
这是我认为没有做任何愚蠢的尝试:
folders.RemoveAll(x => x.SubFolders.Any(c=> c.FolderID == x.FolderID));
而下面是我的MenuFolders实体:
public int FolderID { get; set; }
public string FolderName { get; set; }
public int ParentID { get; set; }
[ForeignKey("ParentID")]
public List<MenuFolder> SubFolders { get; set; }
public Int16 SortOrder { get; set; }
你想从样本中删除哪个'SubFolder 1.1'?第一个还是第二个? _请包含'UserMenuFolders'的源代码._ – mjwills
第二个。如果该文件夹在ForEach后成为孩子,我想将其删除。 – Eric