说到mvc3中的分部视图,不禁联想到webform里面的ascx分部控件,我们在MVC时代可以更加轻松的控制分部视图。MVC中主要分为两大类的分部视图,分别是Html.Partial(partialName)、Html.RenderPartial(partialName)和Html.Action、Html.RenderAction();
(1)Html.Partial(partialName)、Html.RenderPartial(partialName)
●这两个方法我们可以指定任何的.cshtml文件,不一定只是分部视图。MVC中的视图就是有head、body标签,可以定义js,可以指定母版页,但是我们用vs添加分部视图的时 候,会看到只是一些基本的html标签,没有任何head、body,但是这不等于我们不可以添加,所以说partialName可以是任何视图文件。但是最好创建分部视图,因为我们最终 是要把这些分部视图合并为一个页面的,如果只是分部视图的html标签,那么在整体页面中html标签就会很干净。
●最好不要在分部视图中定义或者引用css以及js。如果需要可以再整体页面中定义或引用,因为:分部视图文件和整体页面的路径可能不在同一个目录下,会造成找不到css或js文 件的情况;也可能使得整体页面代码混乱。
(2)Html.Action、Html.RenderAction()
●Action、RenderAction加载方法的视图,执行Controller → Model → View的顺序,然后把产生的页面带回到原来的View中再回传。
●Partial、RenderPartial直接加载视图文件内容
下面举例说明分部视图
示例1
返回一个分部视图的Action
public ActionResult GetUser() { return PartialView(); }
@Html.Partial("GetUser") @{ Html.RenderPartial("GetUser"); }
主视图向分部视图传递Model
@Html.Partial可以将数据实体和数据字典给分部视图,然后分部视图可以通过逐视图传递过去的数据再生成视图。
namespace MvcStart.Controllers { public class HomeController : Controller { public ActionResult Index() { Man_Model man = new Man_Model(); man.Id = 1; man.Name = "张飞"; man.Age = 23; return View(man); } public ActionResult getName(object o) { Man_Model man = o as Man_Model; return PartialView(man); } } public class Man_Model { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } } }
@model MvcStart.Controllers.Man_Model @Model.Id @Model.Age @Html.Partial("getName",Model);
@model MvcStart.Controllers.Man_Model <div style="background-color:red">@Model.Name</div>
<html> <head> <title>Index</title> </head> <body> 23 <div style="background-color:red">张飞</div> </body> </html>
Html.RenderAction()之类的方法还支持传入参数
@Html.RenderAction("Left_Nav", "Nav", new{ ParentId = 3 });
@{ Html.RenderAction("Datagrid", "DataList", new { area = "Common" }); }
原文地址:http://blog.csdn.net/wangboxian/article/details/42124319