0

我试图在视图中使用@(foreach var x in viewbag.data2) 循环显示

 var data = from c in _context.Posts
                       join p in _context.PostViewCount on c.Id equals p.PostId
                       select new
                       {
                           posts = c,
                           p.Count,
                           c.Title,
                           p.PostId

                       };
            var dat = data.OrderByDescending(x=>x.Count).ToList();
            ViewBag.data2 = dat;

我收到无效操作异常

4

2 回答 2

0

你的语法有点错误。

它应该是:

@foreach(var x in ViewBag.data2){

    @x.Count
    @x.Title

}

编辑:因为类型似乎有点混乱dynamic。这个例子展示了如何使用一个定义好的模型。

为您的数据创建一个类,而不是使用匿名对象。

public class PostsModel
{
    public string Title { get; set; }
    public int Count { get; set; }
    // etc...
}

修改您的查询...

var data = from c in _context.Posts
                   join p in _context.PostViewCount on c.Id equals p.PostId
                   select new PostsModel
                   {
                       Count = p.Count,
                       Title = c.Title,
                       // etc...
                   };
        var dat = data.OrderByDescending(x=>x.Count).ToList();
        ViewBag.data2 = dat;

然后只需将您的Viewbag变量转换为正确的类型...

@foreach(PostsModel x in ((IEnumerable<PostsModel>)ViewBag.data2)){

    @x.Count
    @x.Title

}

您可能必须使用以下方法将正确的命名空间导入您的视图:@using <namespace>

于 2019-05-30T10:02:53.610 回答
-1

要访问 viewbag,请在您的视图 @ViewBag.data2 中编写以下代码

它会给你数据。

并将调试器放在上面。你会明白其余的。

于 2019-05-30T09:56:57.463 回答