繁体   English   中英

如何为 c#/ASP.NET/EF Core 中的每个循环编写更好的代码

[英]How to write better code for several for each loops in c# / ASP.NET / EF Core

我想知道如何编写比下面更好的代码。 它有效,但我认为必须有更好的方法来编写它。 也许有一些 Lambda 表达式?

`

var dataList = new List<MyModel>();

        foreach (var data in dataArray)
        {
            var model = new MyModel();
            model.Name = data.Name;
            model.LastName = data.LastName;
            
            model.Model = "";
            model.SubModel = "";

            if (data.Cars.Any())
            {
                foreach (var car in data.Cars)
                {
                    model = new MyModel();
                    model.Name = data.Name;
                    model.LastName = data.LastName;
                    model.Model = car.Model;
                    model.SubModel = "";

                    if (car.SubModels.Any())
                    {
                        foreach (var subModel in car.SubModels)
                        {
                            model = new MyModel();
                            model.Name = data.Name;
                            model.LastName = data.LastName;
                            model.Model = car.Model;
                            model.SubModel = subModel.Model;
                            dataList.Add(model);
                        }
                    }
                    else
                    {
                        dataList.Add(model);
                    }
                }
            }
            else
            {
                dataList.Add(model);
            }
        }

`

试图在 VS 中将其转换为 Lync

伪代码未测试。 您还需要三个构造函数来创建模型类。 或者你用 property init 来做:

new Model() { Name = data.Name, 
LastName = data.LastName, Model = car.Model, SubModel = subModel.Model}
        var dataList = dataArray
          .Select(item => item.Cars)
              .Select(car => new Model(data.Name,data.LastName,car.Model,subModel.Model))
          .Concat(item => item.SubModel
                    .Select(subModel => new Model(data.Name,data.LastName,car.Model,subModel.Model,subModel.Model)))
          .Concat(dataArray.Select(data => new Model(data.Name,data.LastName)))

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM