2016-09-27 79 views
-2

我试图从userList viewbag.i获取值无法找出解决方案。错误是:无法从Viewbag中获得foreach值mvc

An exception of type 'Microsoft.CSharp.RuntimeBinder.RuntimeBinderException' occurred in System.Core.dll but was not handled in user code

Additional information: 'object' does not contain a definition for 'name'

尽管在ViewBag.userList包含数据(2个对象),其在调试

@foreach (var aUser in ViewBag.userList) 
{ 
    <tr> 
     <td>@aUser.name</td> 
     <td>@aUser.username</td> 
     ..... 
     <td>@Html.ActionLink("Edit", "UserEdit","Users")</td> 
     <td>@Html.ActionLink("Delete", "UserDelete", "Users")</td> 
    </tr> 
} 

我可以看到我有一个超类和childclass

public partial class user 
{ 
    public int id { get; set; } 
    public string name { get; set; } 
    public string username { get; set; } 
    ... 
    public string user_role { get; set; } 
} 

孩子类

public class UserSub: user 
{ 
    public string CreatedUserName { get; set; } 
    public string ModifiedUserName { get; set; } 

} 

在我的控制器中,我使用linq从数据库获取值并将其存储到Viewbag.userList中。我的控制器功能是

public ActionResult UserList() 
{ 
    IEnumerable<user> users = null; 
    users = dbEntities.users.ToList(); 

    if (users != null) 
    { 
     var userLists = (from a in users join b in users on a.created_user_id equals b.id select new { a.name, a.username, a.password, a.user_role, a.is_enable, a.is_approved, CreatedUserName = b.name, a.create_time, a.is_android, a.device_id }).ToList(); 
     ViewBag.userList = userLists; 
    } 
    return View(); 
} 

试图List<UserSub> users=ViewBag.userList ....收到错误太

+2

因为'ViewBag.userList'是一个匿名对象的集合。您需要将您的数据投影到模型中(包含属性'name','username','password'等)。不要使用'ViewBag' - 将模型传递给视图) –

+0

试图转换...但也有错误 –

+0

为什么你不能将它作为Model返回视图(userLists);'而不是在ViewBag – Vijai

回答

0

使用视图模型共享视图和控制器之间的数据。

例如,首先创建视图模型

public class userViewModel{  
    public int id { get; set; } 
    public string name { get; set; } 
    public string username { get; set; } 
    public string user_role { get; set; } 
    public string CreatedUserName { get; set; } 
    public string ModifiedUserName { get; set; } 
    ... 
} 

你可以把你在你的视图模型所需要的所有数据...那么,我就建议你用你的模型创建一个类所有你需要的查询(你必须调查怎么做),但是你可以从你的控制器获得查询(如果你想的话)。

好,编辑您的控制器功能:

public ActionResult UserList() 
{ 
    List<userViewModel> userVM = new List<userViewModel>(); //Important! Don't return all the query, just the data that you need. 
    IEnumerable<user> users = null; 
    users = dbEntities.users.ToList(); 

    if (users != null) 
    { 
     var userLists = (from a in users join b in users on a.created_user_id equals b.id select new { a.name, a.username, a.password, a.user_role, a.is_enable, a.is_approved, CreatedUserName = b.name, a.create_time, a.is_android, a.device_id }).ToList(); //I'm going to suppose that your query is ok and you get all the data that you need... 

     foreach (var item in userLists) 
     { 
      userVM.Add(new userVM(){ 
       userVM.name = item.name; 
       userVM.username = item.username; 
       userVM.user_role = item.user_role; 
       ....... 
      });     
     }    
    } 
    return View(userVM); //return your view model 
} 

最后修改视图并调用视图模型userViewModel

@model Model.ViewModel.userViewModel //It depends on the namespace 
//Then try something likes this... 
@foreach (var aUser in Model) 
{ 
    <tr> 
     <td>@aUser.name</td>    
     <td>@aUser.username</td> 
     ..... 
     <td>@Html.ActionLink("Edit", "UserEdit","Users")</td> 
     <td>@Html.ActionLink("Delete", "UserDelete", "Users")</td> 
    </tr> 
} 

这就是理念,提高我的答案。 ;)

+1

只是一个小小的评论 - 你可能在你对谓词(where子句)进行反击之前,不想调用你的'dbEntities.users'上的'ToList()',否则你会从数据库中选择一切并过滤。而不是使用数据库引擎进行过滤(假设适用) – Charleh