首页 > 编程语言 >ASP.NET Core MVC 从入门到精通之布局

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

时间:2023-04-17 18:33:27浏览次数:36  
标签:Core ASP 布局 视图 MVC cshtml NET

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

 

什么是布局?

 

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

 

布局的优势

 

在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占位符。

布局视图示例如下所示:

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

 

指定布局

 

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

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

 

导入共享指令

 

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

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

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

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

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

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

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

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

 

取消布局

 

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

 注意: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>

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

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

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

标签:Core,ASP,布局,视图,MVC,cshtml,NET
From: https://www.cnblogs.com/hsiang/p/17323500.html

相关文章

  • 【Spring MVC + Tomcat】Spring MVC 传统VS现代方式的启动过程对比
    1 前言这节我们来讨论下SpringMVC传统和现在的启动方式的不同,可能大家现在上手就是SpringBoot直接给我们内置Tomcat,我们最多也就是改改配置就完事了,我记得我上学的时候写SSM的时候,还要整理各种Jar包和配置,这节我们就来对比下两种启动方式是如何启动SpringMVC的哈。2  传......
  • 网络安全工程师教你:Kali Linux之Metasploit渗透测试基础(四)
    本分享仅做学习交流,请自觉遵守法律法规!搜索:Kali与编程,学习更多网络攻防干货!下篇文章将在明天下午五点发布,敬请关注!Metasploit渗透测试框架基础(四)一、背景介绍Metasploit就是一个漏洞框架。它的全称叫做TheMetasploitFramework,简称叫做MSF。Metasploit作为全球最受欢迎的工具,不......
  • CefSharp 启动 未能加载由"CefSharp.Core.Runtime.dll"导入的过程
    系统:Windows8.1CefSharp:112.2.70(当前最新稳定版)完整报错信息System.IO.FileLoadException:“未能加载由“CefSharp.Core.Runtime.dll”导入的过程。”  解决Readme.txt中已表示CefSharp109以后的版本不支持Windows10以下的操作系统:也就是说,如果是Windows10以下操......
  • SpringMVC-JSR303和拦截器
    1.JSR3031.1.什么是JSR303JSR是JavaSpecificationRequests的缩写,意思是Java规范提案。是指向JCP(JavaCommunityProcess)提出新增一个标准化技术规范的正式请求。任何人都可以提交JSR,以向Java平台增添新的API和服务。JSR已成为Java界的一个重要标准。JSR-303是JAVAEE6......
  • SpringMvc CRUD
    1.前期准备1.1.配置欢迎页在webapp下添加/home/index.html,再在WEB-INF目录下创建index.jsp(真正的欢迎页面)在web.xml中配置<welcome>标签,并加入/home/index.html<welcome-file-list><welcome-file>/home/index.html</welcome-file></welcome-file-list>通过Controller......
  • gcore的学习
    gcore的学习-解决jmap无法生成dump文件的一种方法背景周末在跆拳道馆看孩子练跆拳道.开着笔记本翻到了扣钉日记公众号里面的讲解想着自己也遇到过无法保存dump文件的情况.所以想学习一下.进行联系其实之前也验证过宕机时的dump文件.感觉是比较类似的.gcoreNAME......
  • How to use the Raspberry Pi to study the Linux kernel source code All In One
    HowtousetheRaspberryPitostudytheLinuxkernelsourcecodeAllInOne如何利用树莓派来研究Linux内核源码AllInOnehttps://github.com/torvalds/linux学习笔记在Linux系统中,一切皆文件!(......
  • abp(net core)+easyui+efcore实现仓储管理系统——模块管理升级之上(六十一)
     Abp(netcore)+easyui+efcore实现仓储管理系统目录abp(netcore)+easyui+efcore实现仓储管理系统——ABP总体介绍(一)abp(netcore)+easyui+efcore实现仓储管理系统——解决方案介绍(二)abp(netcore)+easyui+efcore实现仓储管理系统——领域层创建实体(三) abp(netcore)+e......
  • Raspberry PI 设置开机自启动脚本 All In One
    RaspberryPI设置开机自启动脚本AllInOnedocsraspi-config$sudoraspi-confighttps://www.raspberrypi.com/documentation/computers/configuration.html#raspi-configconfig.txt$cat/boot/config.txt$sudonano/boot/config.txt$sudovim/boot/config.t......
  • SpringMVC中的字符编码问题
    字符编码问题目录字符编码问题一、背景二、排查思路2.1、查看idea默认编码方式2.2、查看接口代码2.3、查看linux编码三、解决思路3.1、修改远程调用编码四、SpringMVC对字符编码的配置4.1、字符编码自动配置类HttpEncodingAutoConfiguration4.2、配置类中属性说明4.3、过滤器中设......