Asp.net mvc 知多少(四)

本系列主要翻译自《ASP.NET MVC Interview Questions and Answers 》- By Shailendra Chauhan,想看英文原版的可访问http://www.dotnettricks.com/free-ebooks自行下载。该书主要分为两部分,ASP.NET MVC 五、ASP.NET WEB API2。本书最大的特色是以面试问答的形式进行展开。通读此书,会帮助你对ASP.NET MVC有更深层次的理解。
因为我的技术水平和英文水平也是有限的,所以错误在所不免,但愿你们多多留言指正。
系列导航
Asp.net mvc 知多少(一)
Asp.net mvc 知多少(二)
Asp.net mvc 知多少(三)
Asp.net mvc 知多少(四)
Asp.net mvc 知多少(五)css

本节主要讲解布局页(Layout)的使用html

Q40. 什么是 ASP.NET MVC的布局页(Layouts)?
Ans. Layouts(布局页)是用来使asp.net mvc中的views保持一致的外观体验。与webforms的master pages功能类似,但比其更加简单且可扩展性更强。下面是一个布局页的代码展现:jquery

<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8" />
 <meta name="viewport" content="width=device-width" />
 <title>@ViewBag.Title</title>
 @Styles.Render("~/Content/css")
 @Scripts.Render("~/bundles/modernizr")
</head>
<body>
 @RenderBody()
 @Scripts.Render("~/bundles/jquery")
 @RenderSection("scripts", required: false)
</body>
</html>

可使用layout为你的网站定义一个通用的模板。layout能够直接在view的顶部直接声明:web

@{
 Layout = "~/Views/Shared/SiteLayout.cshtml";
}

Q41. 介绍下ASP.NET MVC中Sections(节)?
Ans. 经过section能够在layout中指定占用一块内容区域。能够在view中按如下方式定义section。面试

@section header{
<h1>Header Content</h1>
}

在layout中经过@RenderSection("header")去渲染上面定义的section。
默认来讲,若是在layout中定义了须要渲染的section,那么在view中就必须实现。但能够经过如下方式,限定section是可选的。@RenderSection("header",false)
备注:View只能定义已经在layout中指定渲染的section,不然会抛出异常。浏览器


Q42. RenderBody 和 RenderPage 的做用是?
Ans. RenderBody 方法是在layout页面中调用的,是用来渲染呈现子页面/视图。它相似于webform引擎中master页中的ContentPlaceHolder。一个layout页面中只能有一个 RenderBody 方法。网络

<body>
@RenderBody()
@RenderPage("~/Views/Shared/_Header.cshtml")
@RenderPage("~/Views/Shared/_Footer.cshtml")
@RenderSection("scripts",false)
@section scripts{
 <script src="~/Scripts/jquery-1.7.1.min.js"></script>
}
</body>

RenderPage 方法也是在layout页面中用来渲染加应用程序中的其余页面。一个layout页面中能够有多个RenderPage 方法。并发

@RenderPage("~/Views/Shared/_Header.cshtml");

Q43. Styles.Render 和Scripts.Render的功能是?
Ans. 它们是用来捆绑多个css文件和js文件,以提升网络加载速度和页面解析速度。Style.Render是用来呈现定义在BundleConfig.cs中捆绑的css文件。 Styles.Render为捆绑的css建立style标签。
Scripts.Render 也是用来呈现捆绑的script文件。它会为捆绑的script文件建立script标签。mvc

public class BundleConfig
{
 public static void RegisterBundles(BundleCollection bundles)
 {
 bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
 "~/Scripts/jquery.unobtrusive*",
 "~/Scripts/jquery.validate*"));
 bundles.Add(new StyleBundle("~/Content/themes/base/css").Include(
 "~/Content/themes/base/jquery.ui.core.css",
 "~/Content/themes/base/jquery.ui.resizable.css",
 "~/Content/themes/base/jquery.ui.selectable.css",
 "~/Content/themes/base/jquery.ui.button.css",
 "~/Content/themes/base/jquery.ui.dialog.css",
 "~/Content/themes/base/jquery.ui.theme.css"));
 }

当关闭优化时Styles.Render和Scripts.Render会为CSS bundle(script bundle)中的定义的每个css(script)生成一个style(script)标签。当开启优化时, Styles.Render 和Scripts.Render生成惟一的style和script标签,其中带有版本戳的URL表明整个捆绑的css和script。app


Q44. ASP.NET MVC中如何启用捆绑优化?
Ans.
使用BundleTable捆绑多个css文件和js文件,以提升网络加载速度和页面解析速度。
经过在Global.asax.cs文件中修改BundleTable的EnableOptimizations属性来打开和关闭捆绑优化。

protected void Application_Start()
{
 //other code has been removed for clarity 
 //disable optimization
 System.Web.Optimization.BundleTable.EnableOptimizations = false;
}

Q45. 什么是ViewStart?

Ans. _ViewStart.cshml 页面是服务于具备相同布局的view(s) 。该文件代码优于同一目录下的其余view代码先执行。该文件也将递归应用于子文件夹下的view(s)。 默认,
ASP.NET MVC 项目在Views文件夹下仅有一个 _ViewStart.cshtml 文件。该文件中为你mvc 应用程序指定了默认的layout。

@{
 Layout = "~/Views/Shared/Layout.cshtml";
}

由于上面这段代码会在任何view以前运行,因此能够经过override Layout 属性为view指定一个不一样的layout。


Q46. 何时去使用 _ViewStart?
Ans. 当有一系列的view具备相同的设置, 就可使用 _ViewStart.cshtml 来放置通用的视图设置。 若是有任何视图须要修改通用的设置能够经过在view中重载通用设置指定一个新值便可。


Q47. ASP.NET MVC中有哪几种方式去修改默认的layout?

1.修改根目录下的Views文件夹的 _ViewStart文件。_ViewStart为web application定义了默认layout页面。能够经过代码根据不一样的Controller加载不一样的layout。

@{
 var controller =
HttpContext.Current.Request.RequestContext.RouteData.Values["Controller"].ToSt
ring();
 string layout = "";
 if (controller == "Admin")
 {
 layout = "~/Views/Shared/_AdminLayout.cshtml";
 }
 else
 {
 layout = "~/Views/Shared/_Layout.cshtml";
 }
 Layout = layout;
}

2.在Views文件夹的某一个View目录下新增 _ViewStart 文件。

3.在View页面的顶部修改Layout

@{
 Layout = "~/Views/Shared/_AdminLayout.cshtml";
}

4.在ActionResult中指定Layout

public ActionResult Index()
{
 RegisterModel model = new RegisterModel();
 //TO DO:
 return View("Index", "_AdminLayout", model);
}

Q48. 介绍下ASP.NET MVC项目中的App_Start文件夹?
Ans. App_Start文件夹是从MVC4引入的,包含如下配置文件,好比
BundleConfig.cs, FilterConfig.cs,RouteConfig.cs,WebApiConfig.cs 。全部的设置都是在Global.asax.cs文件的Application_Start方法中被注册。

  • BundleConfig.cs - 用来为css和js文件建立和注册捆绑。默认已经包含了对jQuery, jQueryUI, jQuery validation, Modernizr, Site CSS的捆绑。
  • FIlterConfig.cs - 用来注册全局的MVC过滤器,好比error filters, actions filters 等。默认包含 HandleErrorAttribute 过滤器。
  • RouteConfig.cs - 用来注册不一样的路由模式,默认仅注册一个名为Default的路由。
  • WebApiConfig.cs - 用来注册不一样的WEB API 路由,也可用来设置额外的WEB API 配置选项。

Q49. ASP.NET MVC中返回/呈现一个View都有哪几种方式?
Ans. 主要有如下四种方式:

  1. Return View() - 直接告诉MVC去生成指定的将要展现的视图的HTML并发送到浏览器。这个至关于ASP.NET WebForm中的 Server.Transfer() 。
  2. Return RedirectToAction() - 这是告诉MVC去跳转到指定的action而不是直接提供HTML。这种方式下,浏览器将受到跳转通知并从新发送一个指定action的新请求。这个相似与ASP.NET WebForm中的Response.Redirect() 。
    并且, RedirectToAction 会根据路由表构造了一个跳转URL到指定的action/controller。RedirectToAction 会使浏览器收到302重定向状态码。
  3. Return Redirect() - - 这是告诉MVC去跳转到指定的URL而不是直接提供HTML。这种状况下,浏览器收到重定向的通知并从新发送一个指定URL的新请求。相似与ASP.NET WebForm中的Response.Redirect() 。你须要本身构造完整的URL去进行重定向。浏览器一样会收到302重定向状态码。
  4. Return RedirectToRoute() - 这是告诉MVC去路由表中查找指定的路由,而后重定向到路由中定义的controller/action。一样,这也要发起一个新的请求。

备注:

  1. Return View 不会发起一个新的请求。它只是进行视图渲染而不会更改浏览器地址栏的URL。
  2. Return RedirectToAction 发起了一个新的请求,并且浏览器地址栏的URL将被MVC生成的URL更新。
  3. Return Redirect 一样是发起了一个新的请求,且浏览器地址栏的URL将被更新。可是你须要本身指定完整的URL进行重定向
  4. 在 RedirectToAction 和 Redirect之间,最佳实践是在应用程序中的actions/controllers中进行跳转时使用 RedirectToAction。由于若是使用Redirect,一旦你更改了路由表,你就须要手动去更改那些你本身构造的URLs。
  5. RedirectToRoute 重定向到路由表中定义的指定路由。
相关文章
相关标签/搜索