2

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

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

2 回答 2

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;
     }
于 2012-11-24T12:34:46.157 回答
0

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

于 2012-11-24T12:34:04.553 回答