Рекурсия для путей каталогов - PullRequest
0 голосов
/ 03 апреля 2019

Это моя модель для каталога

public class Repositories
{
    public string Id { get; set; }
    public string ParentId { get; set; }
    public string Name { get; set; }
    public string ApplicationName { get; set; }
    public string ApplicationId { get; set; }
    public string Path { get; set; }
    public ICollection<Repositories> RepositoryObjectChildren { get; set; }
    public DateTime CreatedOn { get; set; }
}

Вот так я получаю дерево каталогов.

public List<Repositories> GetRepositoryTree()
{
    List<Repositories> data = new List<Repositories>();
    try
    {
        data = dbContext.Repositories.Include(x => x.RepositoryObjectChildren).Where(x => x.ParentId == null).ToList();
    }
    catch (Exception e)
    {
        logger.LogError(e, LoggingGlobals.NotFound);
        data = null;
    }
    return data;
}

Я не уверен, как продолжить отсюда. Как мне сохранить эту модель? В частности, как сохранить в части ICollection? Я хочу создать каталог папок с подпапками, которые могут иметь подпапки.

1 Ответ

0 голосов
/ 03 апреля 2019

Согласно приведенному выше комментарию, вот рабочий пример того, как вы можете рекурсивно перебирать «плоский» список. Я оставлю это базовым, и вы можете применить его к вашему конкретному варианту использования.

//my test class for the 'flat' folder structure
public class Item
{
    public string Id { get; set; }
    public string ParentId { get; set; }
    public string title { get; set; }
    public List<Item> subs { get; set; }

    public Item()
    {
        this.Id = "";
        this.ParentId = "";
        this.title = "";
        this.subs = new List<Item>();
    }
}

//example using MVC controller
public class YourController : Controller
{
    //var to hold all the 'flat' data
    private List<Item> fulllist = new List<Item>();

    //recursive method to loop through the flat list
    public List<Item> GetChildren(string parentId)
    {
        List<Item> result = new List<Item>();

        foreach (Item child in fulllist.Where(n=>n.ParentId == parentId))
        {
            child.subs = GetChildren(child.Id);
            result.Add(child);
        }

        return result;
    }

    [HttpGet]
    public ActionResult Index()
    {
        //populate the flat list with test data (multi-level)
        fulllist.Add(new Item()
        {Id = "1", ParentId = "", title = "main 1"});
        fulllist.Add(new Item()
        {Id = "2", ParentId = "", title = "main 2"});
        fulllist.Add(new Item()
        {Id = "3", ParentId = "1", title = "main 1 - sub 1"});
        fulllist.Add(new Item()
        {Id = "4", ParentId = "", title = "main 3"});
        fulllist.Add(new Item()
        {Id = "5", ParentId = "4", title = "main 3 - sub 1"});
        fulllist.Add(new Item()
        {Id = "6", ParentId = "5", title = "main 3 - sub 1 - subsub 1"});
        fulllist.Add(new Item()
        {Id = "7", ParentId = "", title = "main 4"});
        fulllist.Add(new Item()
        {Id = "8", ParentId = "7", title = "main 4 - sub 1"});

        //get from the start of the tree
        var output = GetChildren("");

        return Json(output, JsonRequestBehavior.AllowGet);
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...