LINQ错误无效的初始化成员声明器



我是一个相当初级的c#开发人员,所以如果这是微不足道的,请原谅,但是我在下面指示的代码行中出现了这个错误"无效初始化成员声明器"。

有人能解释这意味着什么,我如何工作/实现这个结果?我所有的数据注释都已经在PODetail中应用了一次,这就是为什么我不想在这里重复属性的原因。

public class PODetailsListViewModel : IViewModelList<PODetail, PODetailsListViewModel>, IEntity
    {
        public int Id { get; set; }
        public string EntityDescription
        {
            get
            { return this.Id.ToString(); }
        }
        public PODetail PODetail { get; set; }

        public IEnumerable<PODetailsListViewModel> ConvertClassToViewModel(IEnumerable<PODetail> poDetails)
        {
            IEnumerable<PODetailsListViewModel> contactGrid =
                from l in poDetails.ToList()
                select new PODetailsListViewModel()
                {
                    Id = l.Id,
                    PODetail.POHeaderId = l.POHeaderId, <===== ERROR on this Line
                    ....
                };
            return contactGrid;
        }

你不能像那样在类初始化器中访问复杂的对象属性(就像你正在尝试使用PODetail.POHeaderId属性一样)。您可能不得不实现一个小的解决方案:使用您已经拥有的信息创建一个匿名对象的集合,然后立即重建PODetailsListViewModel的具体列表:

var contactGrid = from l in poDetails.ToList()
                  select new {
                  {
                       Id = l.Id,
                       POHeaderId = l.POHeaderId
                       ...
                  };

然后你可以手动重新创建你正在寻找的内容:

var someNewCollection = New List(Of PODetailsListViewModel);
foreach (var item in contactGrid)
    var model = new PODetailsListViewModel()
    {
         Id = item.Id
    };
    model.PODetail = new PODetailModel() /* replace with actual class name */
    {
        POHeaderId = item.POHeaderId
    };
    someNewCollection.Add(model);
}
return someNewCollection;

EDIT:或者您可以嵌套初始化式:

var contactGrid = from l in poDetails.ToList()
                  select new PODetailsListViewModel() {
                  {
                       Id = l.Id,
                       PODetail = new PODetailModel()
                       {
                           POHeaderId = l.POHeaderId
                       },
                       ...
                  };

相关内容

  • 没有找到相关文章