4

我正在尝试发送到视图IEnumerable并显示其中的每个元素,但是发送时出现问题。它说:

{System.Linq.Enumerable.WhereSelectEnumerableIterator<System.Linq.IGrouping<string,MvcApplication4.Models.USER>,<>f__AnonymousType8<string,int>>}

我不知道如何处理它。

这是我的观点:

@model  IEnumerable<dynamic>

我得到dynamic是因为我从几个函数中看到了这个视图,它们是如何发送不同类型的。

 <table border="1"  style="text-align:center">
      <tr>
          <td> </td>
          <td> user name </td>  
          <td>age </td>  
          <td>comments </td>
      </tr>

      @foreach (var t in (Model))
      {
      <tr>                                           
          <td>@(count++))</td>
          <td> @Console.WriteLine(t)</td>  
          <td>  </td>  
          <td> </td>
      </tr>                                    
      }

 </table>

IEnumerable从这个 linq 得到:

 var allU = (from m in comList
                    join c in users on m.user equals c.user into cm1
                    from cm2 in cm1.DefaultIfEmpty()
                    group cm2 by m.user into grouped
                    select new { name = grouped.Key, count = grouped.Count() }).AsEnumerable();

所以我的问题真的是:我怎样才能在视图中获取它的元素?

4

1 回答 1

3

您不能在视图中引用该类型,因为它是匿名类型。相反,定义一个类型来存储查询结果:

public class Result
{
  public string Name { get; set; }
  public int Count { get; set; }
}

然后将您的查询更改为该类型:

var allU = (from m in comList
                    join c in users on m.user equals c.user into cm1
                    from cm2 in cm1.DefaultIfEmpty()
                    group cm2 by m.user into grouped
                    select new Result { Name = grouped.Key, Count = grouped.Count() }).AsEnumerable();

然后,您将能够绑定到IEnumerable<Result>视图中的类型。

于 2013-01-12T14:33:44.050 回答