开发者

Stuffing an anonymous type in ViewBag causing model binder issues

can someone tell me what I'm doing wrong? :-)

I have this simple query:

 var sample = from 开发者_运维知识库training in _db.Trainings
              where training.InstructorID == 10
              select new { Something = training.Instructor.UserName };

And I pass this to ViewBag.

ViewBag.Sample = sample;

Then I want to access it in my view like this:

@foreach (var item in ViewBag.Sample) {
    @item.Something
}

And I get error message 'object' does not contain a definition for 'Something'. If I put there just @item, I get result { Something = SomeUserName }

Thanks for help.


This cannot be done. ViewBag is dynamic and the problem is that the anonymous type is generated as internal. I would recommend you using a view model:

public class Instructor
{
    public string Name { get; set; }
}

and then:

public ActionResult Index()
{
    var mdoel = from training in _db.Trainings
                 where training.InstructorID == 10
                 select new Instructor { 
                     Name = training.Instructor.UserName 
                 };
    return View(model);
}

and in the view:

@model IEnumerable<Instructor>
@foreach (var item in ViewBag.Sample) {
    @item.Something
}


If you want to send in ViewData For example and don't want to send in model you could use the same could as in the upper answer and in the Controller

enter code here


ViewData[Instractor] = from training in _db.Trainings
                 where training.InstructorID == 10
                 select new Instructor { 
                     Name = training.Instructor.UserName 
                 };

and in the view you need to cast this to

`IEnumerable<Instructor>`

but to do this you should use

@model IEnumerable<Instructor>

Then you could do something like this

IEnumerable<instructors> Instructors =(IEnumerable<Instructor>)ViewData[Instractor];

then go with foreach

@foreach (var item in Instructors ) {
    @item.Something
}
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜