2012-11-24 17 views
2

如何通过在这种情况下使用lambda或linq来避免使用嵌套的foreach语句?现在已经很晚了,我似乎无法弄清楚如何访问ErrorMessage属性而不必恢复到嵌套的foreach语句。如果完全使用Lambda或Linq重写代码,那么等效方法是什么?如何通过在这种情况下使用lambda或linq来避免使用嵌套的foreach语句?

public static List<String> ExtractErrors(this ModelStateDictionary modelStateDictionary) 
     { 
      List<String> errors = new List<String>(); 

      var modelErrorCollection = (from modelState in modelStateDictionary.Values 
             where modelState.Errors != null && modelState.Errors.Count > 0 
             select modelState.Errors).ToList(); 

      foreach (var item in modelErrorCollection) 
      { 
       foreach (ModelError modelError in item) 
       { 
        errors.Add(modelError.ErrorMessage); 
       } 
      } 

      return errors; 
     } 

回答

4

你要使用SelectMany这个

public static List<String> ExtractErrors(this ModelStateDictionary modelStateDictionary) 
    { 
     var modelErrorCollection = (from modelState in modelStateDictionary.Values 
            where modelState.Errors != null && modelState.Errors.Count > 0 
            select modelState.Errors) 
            .SelectMany(item=>item) 
            .Select(modelError=>modelError.ErrorMessage) 
            .ToList(); 
     return modelErrorCollection; 
    } 
+0

它编译 - 谢谢:) – CarneyCode

0

是不是errors.Add(modelErrorCollection.SelectMany(x => x))

+0

请解释一下:) – CarneyCode

相关问题