asp.net core学习笔记——视图共享

母版页

  • 实现视图共享,需要修改的时候,只需要修改一句就行

  • 一般在/Views/Shared目录下

/Views/Shared目录下新建MyMasterPage.cshtml文件

<html>
<head>
    <title></title>
</head>
<body>
    这是页面顶部内容 <br />

    @* 使用RenderBody来显示页面内容 *@
    @RenderBody()

    <br />
    这是页面底部内容
</body>
</html>

鼠标放在控制器的方法名上,右键添加视图选择视图模板:


@{
    ViewData["Title"] = "Index";
    Layout = "~/Views/Shared/MyMasterPage.cshtml";
}

<h2>Index</h2>

这是内容
  • 内容隔离

子页面:


@{
    ViewData["Title"] = "Index";
    Layout = "~/Views/Shared/MyMasterPage.cshtml";
}

@section section1{
    这是section1的内容
}

@section section2{
    这是section2的内容
}

<h2>子页面主体</h2>

母版

<html>
<head>
    <title></title>
</head>
<body>
    这是页面顶部内容 <br />

    @* 第二个参数表示分区是否是必须的 *@
    @RenderSection("section1",false)

    @RenderBody()

    @RenderSection("section1")

    <br />
    这是页面底部内容
</body>
</html>
  • 母版页数据绑定和普通数据绑定一致

Controller

using Microsoft.AspNetCore.Mvc;

namespace WebApplication1.Controllers
{
    [Controller]
    public class Test : Controller
    {
        public  IActionResult Index()
        {
            ViewBag.Username = "张三";
            return View();
        }
    }
}

母版页:

<html>
<head>
    <title></title>
</head>
<body>
    这是页面顶部内容 <br />

    @ViewBag.Username
    @RenderBody()

    <br />
    这是页面底部内容
</body>
</html>

子页面


@{
    ViewData["Title"] = "Index";
    Layout = "~/Views/Shared/MyMasterPage.cshtml";
}


<h2>@ViewBag.Username</h2>

部分视图

  • 直接引入部分视图

/Views/Shared目录下新建一个MyPartPage.cshtml的文件

<h2>这是部分共享视图</h2>

Index视图里面引入

<html>
<head>
    <title></title>
</head>
<body>
    @Html.Partial("~/Views/Shared/MyPartPage.cshtml")
</body>
</html>
  • 也可以直接在控制器里面返回部分视图,一般用于局部刷新(ajax)
using Microsoft.AspNetCore.Mvc;

namespace WebApplication1.Controllers
{
    [Controller]
    public class Test : Controller
    {
        public  IActionResult Index()
        {
            return PartialView("~/Views/Shared/MyPartPage.cshtml");
        }
    }
}

ViewStart

  • 视图呈现之前执行
  • 可以做全局性数据初始化,比如母版指定
  • _ViewStart.cshtml命名,固定名称,不能更换
  • 一般放在视图所在目录的根目录下
  • 自动执行,无需手工调用
  • 不要在ViewStart中做大量业务操作

ViewImports

  • _ViewImports.cshtml命名,固定名称,不能更换
  • 只能做引入操作
  • 一般放在视图所在目录的根目录下
  • 自动执行,无需手工调用
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值