MVC3分部视图

说到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");
    }

示例2

主视图向分部视图传递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; }
    }
}

视图代码:Index.cshtml

@model MvcStart.Controllers.Man_Model
@Model.Id
@Model.Age

@Html.Partial("getName",Model);

getName.cshtml


@model MvcStart.Controllers.Man_Model
<div style="background-color:red">@Model.Name</div>

生成的HTML代码为:

<html>
<head>
    <title>Index</title>
</head>

<body>
23
<div style="background-color:red">张飞</div>
</body>
</html>

示例3

Html.RenderAction()之类的方法还支持传入参数

@Html.RenderAction("Left_Nav", "Nav", new{ ParentId = 3 });

@{ Html.RenderAction("Datagrid", "DataList", new { area = "Common" });    }

在Action里面直接加个参数ActionResult(int ParentId)就能够取得参数值。area会被MVC所截取,分析为跨区域调用。



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值