繁体   English   中英

如何在foreach循环mvc3中遍历两个表的模型

[英]how to iterate through model of two table in foreach loop mvc3

我有鉴于自定义模型而用foreach循环进行迭代的问题。我正在尝试为剃刀创建动态菜单,这是我的代码:

模型:

public class MenuCtrlModel

{
    public IList<Menu> menu { get; set; }
    public IList<SubMenu> subMenu { get; set; }
}

控制器:

    public PartialViewResult Index()

    {
        var nuser = dataContext.UserLogins.SingleOrDefault(x => x.nvrchrUsername == User.Identity.Name);
        string[] menu = nuser.vcrMenu.ToString().Split('|').ToArray();

        string[] subMenu = nuser.vcrSubmenu.ToString().Split('|').ToArray();

        MenuCtrlModel menuctrl = new MenuCtrlModel();

        menuctrl.menu = (from varMenu in dataContext.Menus where            menu.Contains( Convert.ToString( varMenu.intMenuID ) ) select varMenu).ToList();

        menuctrl.subMenu=(from varSubmenu in dataContext.SubMenus where 
 subMenu.Contains( Convert.ToString(varSubmenu.intSubMenu ) ) select varSubmenu ).ToList();
    }  

查看:这给了我错误

**@model IList<MVCAPP.Models.MenuCtrlModel>
@foreach(var xyz in Model.select(x=>x.menu))

{

    @Html.RouteLink(xyz.Select(x=>x.nvcrMenuName), new { controller = xyz.Select(x=>x.nvcrLink),action=xyz.Select(x=>x.nvcrLink) })}

}
**

我也尝试过

@foreach(var xyz in Model)

当我尝试查找诸如Model.Menu之类的菜单列表时,不是菜单未在intellisense **中出现**,请提出如何解决此问题的建议。

谢谢。

由于ModelMenuCtrlModel的列表,每个列表都有一个menu属性,因此Model.select(x=>x.menu)将返回一个集合的集合。

我认为您想循环浏览每个项目,然后循环浏览每个项目中的菜单:

@foreach(var menuModel in Model))
    @foreach(var menu in menuModel.menu))    

尽管我无法告诉您该子菜单是如何链接的,否则将为您提供更多帮助。

您将需要SelectMany,因为您的模型也是一个集合。

@model IList<MVCAPP.Models.MenuCtrlModel>
@foreach(var menu in Model.SelectMany(x => x.Menu))
{
    @Html.RouteLink(menu.nvcrMenuName, new { controller = menu.nvcrLink, action=menu.nvcrLink })
}

另外, IList<MVCAPP.Models.MenuCtrlModel>是一个错误,您的控制器代码似乎表明您实际上只有一个MenuCtrlModel ,因此模型行需要更正吗?

@model MVCAPP.Models.MenuCtrlModel
@foreach(var menu in Model.Menu)
{
    @Html.RouteLink(menu.nvcrMenuName, new { controller = menu.nvcrLink, action=menu.nvcrLink })
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM