ASP.NET Core MVC 从入门到精通之布局

随着技术的发展,ASP.NET Core MVC也推出了好长时间,经过不断的版本更新迭代,已经越来越完善,本系列文章主要讲解ASP.NET Core MVC开发B/S系统过程中所涉及到的相关内容,适用于初学者,在校毕业生,或其他想从事ASP.NET Core MVC 系统开发的人员。 经过前几篇文章的讲解,初步了解ASP.NET Core MVC项目创建,启动运行,以及命名约定,创建控制器,视图,模型,接收参数,传递数据,路由等内容,今天继续讲解ASP.NET Core MVC 布局等相关内容,仅供学习分享使用。

ASP.NET Core MVC 从入门到精通之布局

 

什么是布局?

 

大多数 Web 应用都有一个通用布局,可在页面间切换时为用户提供一致体验。 该布局通常包括应用标头、导航或菜单元素以及页脚等常见的用户界面元素。在如下布局中,Content内容随着不同请求而改变,其他页面内容则很少改变,进而形成统一的风格,一致的用户体验,这就是布局的好处。

ASP.NET Core MVC 从入门到精通之布局

 

布局的优势

 

在ASP.NET Core MVC项目中,使用布局具有以下几个优势:

  1. 布局可使页面在不同的请求之间保持一致的用户体验。
  2. 布局可减少视图中的重复代码。

 

布局的分类

 

按照约定,默认布局名为 _Layout.cshtml。 使用模板创建的新 ASP.NET Core 项目的布局文件为:

  • 基于页面的布局文件,Razor 页面: Pages/Shared/_Layout.cshtml
  • 基于视图控制器的布局文件,具有视图的控制器: Views/Shared/_Layout.cshtml

 

默认布局

 

在通过模板创建的ASP.NET Core MVC项目中,默认会生成布局视图【Views/Shared/_Layout.cshtml】,布局视图主要包括三部分:

  1. 引入公共的JavaScript脚本,CSS样式等资源文件
  2. 定义公共的Header,Footer,Left Navigation等用户页面元素
  3. 定义Content区域,通过@RenderBody()来提供Content占位符。

布局视图示例如下所示:

ASP.NET Core MVC 从入门到精通之布局

默认情况下,每个布局必须调用 RenderBody。 无论在何处调用 RenderBody,都会呈现视图的内容。

 

指定布局

 

视图具有Layout属性,可以指定使用不同的布局视图。指定的布局可以使用完整路径 (,例如/Views/Shared/_Layout.cshtml/Pages/Shared/_Layout.cshtml) 或部分名称 (示例: _Layout) 。 

默认情况下【_ViewStart.cshtml】指定默认的布局视图,页面内容如下所示:

ASP.NET Core MVC 从入门到精通之布局

 

导入共享指令

 

视图和页面可以使用 Razor 指令来导入命名空间并使用依赖项注入。 可在一个共同的 _ViewImports.cshtml 文件中指定由许多视图共享的指令。 _ViewImports 文件支持以下指令:

  • @addTagHelper
  • @removeTagHelper
  • @tagHelperPrefix
  • @using
  • @model
  • @inherits
  • @inject
  • @namespace

注意:该文件不支持函数和节定义等其他 Razor 功能。

默认情况下,【_ViewImports.cshtml】页面内容如下所示:

ASP.NET Core MVC 从入门到精通之布局

 _ViewStart.cshtml,_ViewImports.cshtml 通常放置在 Pages (或 Views) 文件夹中。如下所示:

ASP.NET Core MVC 从入门到精通之布局

 注意:_ViewImports.cshtml文件可以放置在任何文件夹中,在这种情况下,该文件将仅应用于该文件夹及其子文件夹中的页面或视图。 从根级别开始处理 _ViewImports 文件,然后处理在页面或视图本身的位置之前的每个文件夹。 可以在文件夹级别覆盖根级别指定的 _ViewImports 设置。

如果在文件层次结构中找到多个 _ViewImports.cshtml 文件,则指令的组合行为如下所示:

  • @addTagHelper@removeTagHelper:按顺序全部运行
  • @tagHelperPrefix:最接近视图的文件会替代任何其他文件
  • @model:最接近视图的文件会替代任何其他文件
  • @inherits:最接近视图的文件会替代任何其他文件
  • @using:全部包括在内;忽略重复项
  • @inject:针对每个属性,最接近视图的属性会替代具有相同属性名的任何其他属性

 

取消布局

 

通过默认模板创建的程序,默认是应用布局文件,效果如下:

ASP.NET Core MVC 从入门到精通之布局

 注意:content内容也应用了布局文件中公共的css样式和javascript脚本等资源。

在视图中,通过指定Layout属性可以取消或替换布局,如下所示:

1 @{
2     ViewData["Title"] = "Home Page";
3     Layout = null;
4 }
5 
6 <div class="text-center">
7     <h1 class="display-4">Welcome</h1>
8     <p>Learn about <a href="https://docs.microsoft.com/aspnet/core">building Web apps with ASP.NET Core</a>.</p>
9 </div>

取消布局效果,如下所示:

ASP.NET Core MVC 从入门到精通之布局

通过对比发现,取消布局后,原有的居中效果也消失了。说明失去了原有布局文件中css样式的支持。

以上就是ASP.NET Core MVC从入门到精通之布局的全部内容,旨在抛砖引玉,一起学习,共同进步。

原文链接:https://www.cnblogs.com/hsiang/p/17323500.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:ASP.NET Core MVC 从入门到精通之布局 - Python技术站

(0)
上一篇 2023年4月22日
下一篇 2023年4月22日

相关文章

  • Visual Studio寻找C#程序必要的运行库文件

    当我们用Visual Studio创建C#程序并尝试运行时,有时可能会遇到找不到必要的运行库文件的情况。为了解决这个问题,可以采用以下攻略。 第一步:检查程序是否需要的运行库 首先需要确认程序是否真的需要依赖于某个运行库,我们可以通过查看程序的引用来确定是否有引用第三方库或系统库,如果有,就需要检查这些库是否被正确地安装在了计算机中。 第二步:检查项目属性 …

    C# 2023年6月1日
    00
  • C# 调用腾讯即时通信 IM的示例

    下面是“C#调用腾讯即时通信IM的示例”的完整攻略。 背景 腾讯为开发者提供了强大的即时通信 IM(Instant Messaging)服务,包括基础的即时通信功能、客户端与服务器端 API 平台、即时消息推送等功能。开发者可以通过 API 方式接入 IM 服务,为用户提供一些高性能、高可靠,且全面、专业的即时通信解决方案。 本文将介绍如何使用 C# 编写程…

    C# 2023年5月31日
    00
  • asp.net 程序性能优化的七个方面 (c#(或vb.net)程序改进)

    下面是“asp.net程序性能优化的七个方面(c#(或vb.net)程序改进)”的完整攻略: 1. 数据库优化 在开发asp.net程序时,数据库访问是性能瓶颈之一。为提高程序性能,需要优化数据库设计和访问方式。具体可以从以下几个方面着手: 1.1 数据库设计优化 合理的数据库设计可以降低数据表冗余度,提高数据读写效率。具体可以优化以下几个方面: 表设计:合…

    C# 2023年5月15日
    00
  • JS关键字球状旋转效果的实例代码

    JS关键字球状旋转效果的实例代码 JS关键字球状旋转效果是一种常见的Web前端效果,可以通过JavaScript和CSS实现。本文将提供详细的“JS关键字球状旋转效果的实例代码”的完整攻略,包括如何使用JavaScript和CSS实现关键字球状旋转效果,以及两个示例代码。 使用JavaScript和CSS实现关键字球状旋转效果 在使用JavaScript和C…

    C# 2023年5月15日
    00
  • 计算机网络编程MQTT协议基础原理详解

    计算机网络编程MQTT协议基础原理详解 什么是 MQTT 协议? MQTT 是一种轻量级的,基于发布/订阅模式的通信协议,适用于 Internet of Things(IoT)领域中的低带宽、不可靠的网络环境。 mqtt 协议构建于 TCP/IP 协议之上,通信双方包括一个客户端和一个服务器(也称为代理或 broker)。客户端面向应用系统,将数据发布到服务…

    C# 2023年6月1日
    00
  • C# 标准事件流实例代码

    首先,我们需要了解什么是 C# 标准事件流。C# 标准事件流是一种事件源和事件处理程序之间的机制,允许一个或多个事件处理程序能够对事件进行处理。 下面是一个 C# 标准事件流实例代码的完整攻略: 1. 定义事件和事件处理程序 首先,我们需要定义一个事件和至少一个事件处理程序。在这个例子中,我们定义了一个名为 ButtonClick 的事件和一个名为 OnBu…

    C# 2023年6月7日
    00
  • C#创建控制Windows服务

    创建 Windows 服务可以让我们的程序在后台运行,从而实现一些后台任务,例如数据同步、邮件服务等。C#作为一门强大的编程语言,可以很方便地创建Windows服务。本文将提供C#创建控制Windows服务的完整攻略,内容包括创建 Windows 服务、安装和卸载服务、启动和停止服务,以及包含两个示例说明。 创建 Windows 服务 创建 Windows …

    C# 2023年6月3日
    00
  • C# DateTime.AddYears()方法: 将指定的年份数加到指定的日期上

    DateTime.AddYears()是C#中DateTime结构的一个方法,它用于增加指定的年数,并返回一个新的DateTime对象。它的使用方法如下: DateTime newDate = DateTime.Now.AddYears(2); 上述代码将获取当前时间,并增加2年,最后返回一个新的时间对象newDate。 可以使用AddYears()方法来计…

    C# 2023年4月19日
    00
合作推广
合作推广
分享本页
返回顶部