HTML.Action()和HTML.RenderAction()类似于HTML.Partial()和HTML.RenderPartial()辅助方法。Partial辅助方法通常在单独的文件中应用视图标记来帮助视图渲染视图模型的一部分。另一方面,Action是执行单独的控制器操作并显示结果。Action提供了更多的灵活性和重用性,因为控制器操作可以建立不同的模型,可以利用单独的控制器上下文。
示例目的,生成一个菜单
Menu Models,
public class Menu { public List<MenuItem> Items { get; set; } } public class MenuItem { public string Text { get; set; } public string Url { get; set; } }
在Controler中编写该Action,
[ChildActionOnly] public ActionResult MyMenu() { MvcLearn.Models.Menu m = new MvcLearn.Models.Menu(); List<MvcLearn.Models.MenuItem> items = new List<MenuItem>(); items.Add( new MenuItem(){ Text = "Baidu", Url = "http://www.baidu.com"}); items.Add(new MenuItem() { Text = "Sina", Url = "http://www.Sina.com" }); items.Add(new MenuItem() { Text = "IBM", Url = "http://www.ibm.com" }); items.Add(new MenuItem() { Text = "Sohu", Url = "http://www.sohu.com" }); m.Items = items; return PartialView(m); }
建立一个PartialView - MyMenu.cshtml
@model MvcLearn.Models.Menu <ul> @foreach(var item in Model.Items) { <li><a href="@item.Url">@item.Text</a></li> } </ul>
在页面中调用该Action生成视图:
@Html.Action("MyMenu")
Action和PartialView的名字要一样,这里都是MyMenu
以下是向Action传递参数的版本:
修改Action让它可以接受一个MenuItem参数,如果不为空的话,将其加入到菜单中
[ChildActionOnly] public ActionResult MyMenu(MenuItem mi) { MvcLearn.Models.Menu m = new MvcLearn.Models.Menu(); List<MvcLearn.Models.MenuItem> items = new List<MenuItem>(); items.Add( new MenuItem(){ Text = "Baidu", Url = "http://www.baidu.com"}); items.Add(new MenuItem() { Text = "Sina", Url = "http://www.Sina.com" }); items.Add(new MenuItem() { Text = "IBM", Url = "http://www.ibm.com" }); items.Add(new MenuItem() { Text = "Sohu", Url = "http://www.sohu.com" }); m.Items = items; // 这里,如果传入的参数不为空,则将Item加入到菜单中 if(mi!=null) m.Items.Add(mi); return PartialView(m); }
在前台调用的时候要传入参数进去:
@Html.Action("MyMenu", new { mi= new MvcLearn.Models.MenuItem(){ Text = "haha", Url =http://www.ms.com}})
这里的参数mi 必须要跟在action中定义的形式参数mi名称保持一致,否则值可能无法成功传递!!!