您的位置:首页 > 编程语言 > ASP

Asp.net mvc 知多少(三)

2017-01-17 20:32 302 查看

本系列主要翻译自《ASP.NET MVC Interview Questions and Answers 》- By Shailendra Chauhan,想看英文原版的可访问http://www.dotnettricks.com/free-ebooks自行下载。该书主要分为两部分,ASP.NET MVC 5、ASP.NET WEB API2。本书最大的特点是以面试问答的形式进行展开。通读此书,会帮助你对ASP.NET MVC有更深层次的理解。

由于个人技术水平和英文水平也是有限的,因此错误在所难免,希望大家多多留言指正。

系列导航

Asp.net mvc 知多少(一)

Asp.net mvc 知多少(二)

Asp.net mvc 知多少(三)


本节主要讲解视图引擎及HtmlHelper的使用

Q24. ASP.NET MVC中主要的命名空间有哪些?

Ans. 主要有以下三个比较重要的命名空间:

System.Web.Mvc - 此命名空间包含类和接口是为了支持ASP.NET Web应用程序的Mvc模式。主要包括:Controllers、Controller factories、action results、views、partial views、model binders。

System.Web.Mvc.Ajax - 支持Ajax脚本。此命名空间主要是为了支持Ajax脚本已经Ajax选项设置。

System.Web.Mvc.Html – 此命名空间帮忙渲染HTML控件。主要用来支撑 forms, input controls, links, partial views,

validation.

Q25. 什么是视图引擎?

Ans. 视图引擎作为mvc的子系统拥有自身的语义标记。它的职责是转换服务器模板为html标记并渲染呈现到浏览器。最初,ASP.mvc只有一种视图引擎web forms(aspx) ,从ASP.NET MVC3 引入了新的Razor视图引擎。除此之外,还有 Spark, NHaml 等第三方视图引擎。

Q26. 视图引擎是怎样工作的?

Ans. 每种视图引擎主要包括以下三个主要部分:

ViewEngine class - 实现自
IViewEngine
接口;职责是定位视图模板的位置。

View class - 实现自
IView
接口;职责是从当前的上下文去合并数据与模板并转换为输出的Html标记。

Template parsing engine (模板解析引擎)- 解析模板和编译视图为可执行代码。

Q27. 介绍下Razor视图引擎?

Ans. Razor引擎是从MVC3引入的一种高级视图引擎。Razor不是一种新的语言而是一种新的标记语义。 Razor提供的语义减少用户输入且富于表现力。相较于Web From 语义更加简洁且容易学习。Razor使用**@**符号去书写标记
@Html.ActionLink("SignUp", "SignUp")


Q28. 如何自定义视图引擎?

Ans. ASP.NET MVC 是一个开源并且高度可扩展的框架。可以通过实现IViewEngine 接口或者继承 VirtualPathProviderViewEngine 抽象类来实现自定义视图引擎。

public class CustomViewEngine : VirtualPathProviderViewEngine
{
public CustomViewEngine()
{
// Define the location of the View and Partial View
this.ViewLocationFormats = new string[] { "~/Views/{1}/{0}.html",
"~/Views/Shared/{0}.html" };
this.PartialViewLocationFormats = new string[] { "~/Views/{1}/{0}.html",
"~/Views/Shared/{0}.html" };
}
protected override IView CreatePartialView(ControllerContext
controllerContext, string partialPath)
{
var physicalpath =
controllerContext.HttpContext.Server.MapPath(partialPath);
return new CustomView(physicalpath);
}
protected override IView CreateView(ControllerContext controllerContext,
string viewPath, string masterPath)
{
var physicalpath =
controllerContext.HttpContext.Server.MapPath(viewPath);
return new CustomView(physicalpath);
}
}
public class CustomView : IView
{
private string _viewPhysicalPath;
public CustomView(string ViewPhysicalPath)
{
_viewPhysicalPath = ViewPhysicalPath;
}
public void Render(ViewContext viewContext, System.IO.TextWriter writer)
{
//Load File
string rawcontents = File.ReadAllText(_viewPhysicalPath);
//Perform Replacements
string parsedcontents = Parse(rawcontents, viewContext.ViewData);
writer.Write(parsedcontents);
}
public string Parse(string contents, ViewDataDictionary viewdata)
{
return Regex.Replace(contents, "\\{(.+)\\}", m => GetMatch(m, viewdata));
}
public virtual string GetMatch(Match m, ViewDataDictionary viewdata)
{
if (m.Success)
{
string key = m.Result("$1");
if (viewdata.ContainsKey(key))
{
return viewdata[key].ToString();
}
}
return string.Empty;
}
}


Q29. 如何注册自定义视图引擎?

Ans. 通过在global.asax.cs文件的
Application_Start()
方法注册自定义视图引擎,来告诉ASP.NET MVC来使用自定义视图引擎替换默认的视图引擎。

protected void Application_Start()
{
//Register Custom View Engine
ViewEngines.Engines.Add(new CustomViewEngine());

//other code is removed for clarity
}

Q30. 能否删除默认的视图引擎?

Ans. 当然可以删除微软提供达到默认搜索引擎,Razor和Web Froms(aspx)。

protected void Application_Start()
{
//Remove All View Engine including Webform and Razor
ViewEngines.Engines.Clear();
}


Q31. Razor和WebForm 引擎的主要区别有哪些?

RazorWebForm
MVC3后引入最初的MVC版本就引入
位于System.Web.Razor命名空间位于System.Web.Mvc.WebFormViewEngine命名空间
状态管理技术(View State、Session)没有自动的状态管理
基于文件路径的路由基于路由的Urls
统一的文件后缀 .cshtml(C#)视图后缀为.aspx,分部视图或编辑模板为.ascx
View与业务逻辑紧耦合(.aspx,.aspx.cs)View与业务逻辑分离
@ 符号书写方式@Html.ActionLink("SignUp", "SignUp")<%: Html.ActionLink("SignUp", "SignUp") %>
默认支持阻止XSS攻击不支持
不能通过拖拽控件进行布局可以
支持TDD不支持TDD
Q33. 列举下都有哪几种HTML Helpers?

Ans. 主要有三种Html Helpers:

1、** Inline Html Helpers **- 通过Razor@helper标签创建的帮助类,只能在同一个view中使用。

@helper ListingItems(string[] items)
{
<ol>
@foreach (string item in items)
{
<li>@item</li>
}
</ol>
}
<h3>Programming Languages:</h3>
@ListingItems(new string[] { "C", "C++", "C#" })
<h3>Book List:</h3>
@ListingItems(new string[] { "How to C", "how to C++", "how to C#" })

2、 Built-In Html Helpers - Built-In Html Helpers 是针对
HtmlHelper
的扩展方法。主要分为三类:

2.1 Standard Html Helpers - 用于渲染常见的Html 元素:



2.2 Strongly Typed HTML Helpers - 基于model属性创建的html元素,主要是通过lambda表达式来创建元素。



2.3 Templated HTML Helpers - 该类型帮助类,会自动根据model类的属性类型去呈现适当的html元素。

比如你的属性使用[DataType(DataType.Password)]属性注解为Password,那么使用模板html帮助类,它将自动呈现为密码类型的文本框。
<input id="Password" name="Password" type="password"/>




Display and DisplayFor:根据指定的model属性和基于model属性的数据类型和元数据选择一个合适的html标签去渲染【只读状态的视图】 。

Editor and EditorFor:根据指定的model属性和基于model属性的数据类型和元数据选择一个合适的html标签去渲染【编辑状态的视图】。

3、 Custom Html Helpers - 可以通过扩展
HtmlHelper
类或者通过创建在工具类中创建静态方法来创建自定义Html Helper。

public static class CustomHelpers
{
//Submit Button Helper
public static MvcHtmlString SubmitButton(this HtmlHelper helper, string buttonText)
{
string str = "<input type=\"submit\" value=\"" + buttonText + "\"/>";
return new MvcHtmlString(str);
}
//Readonly Strongly-Typed TextBox Helper
public static MvcHtmlString TextBoxFor<TModel, TValue>(this HtmlHelper<TModel> htmlHelper, Expression<Func<TModel,TValue>>expression, bool isReadonly)
{
MvcHtmlString html = default(MvcHtmlString);
if (isReadonly)
{
html = System.Web.Mvc.Html.InputExtensions.TextBoxFor(htmlHelper, expression, new { @class = "readOnly", @readonly = "read-only" });
}
else
{
html = System.Web.Mvc.Html.InputExtensions.TextBoxFor(htmlHelper, expression);
}
return html;
}
}


Q34. 介绍下Url Helpers?

Ans. Url helpers 基于路由配置帮助我们去渲染HTML链接或生成URL。



Q35. 什么是 Validation Summary(验证汇总)?

Ans. ValidationSummary是用来显示ModelState字典中所有验证错误信息 (未经排序)。它接收一个bool参数,当
@Html.ValidationSummary(true)
显示model-level错误;当
@Html.ValidationSummary(false)
显示model-level 和 property-level 错误。

假设你在代码中添加了如下两行代码:

ModelState.AddModelError("", "This is Model-level error!");
ModelState.AddModelError("Name", "This Model property-level error!");

第一行未指定key关联这个错误信息;第二行指定Name属性关联。

当在view中分别使用以下两种方式现在验证信息:

@Html.ValidationSummary(true) @*//shows model-level errors*@
@Html.ValidationSummary(false) @*//shows model-level and property-level errors*@

因此,为true时,只显示model级别错误信息。

为false时,即显示model级别,也显示model的属性级别的错误。

Q36. 介绍下 AJAX Helpers?

Ans. AJAX Helpers 是用来创建启用Ajax进行异步加载的元素比如Ajax From,Ajax 链接。 AJAX Helpers 是
System.Web.Mvc
命名空间中
AJAXHelper
类的扩展方法。

@Ajax.ActionLink("Load Products", "GetProducts", new AjaxOptions {UpdateTargetId= "Products-container", HttpMethod = "GET" })

//输出:
<a data-ajax="true" data-ajax-method="GET" data-ajax-mode="replace"
data-ajax-update="#Products-container" href="/Home/GetProducts">Load Products</a>


Q37.什么是非侵入Ajax (unobtrusive AJAX)?

Ans. ASP.NET MVC提供了基于jquery的非侵入ajax。非侵入式ajax意味着通过使用帮助类方法去定义ajax功能而不是通过在view中添加js代码块。

Q38. 介绍下AJAX帮助类的配置选项?

Ans.
AjaxOptions
类定义的属性允许你在ajax请求的生命周期中的不同阶段指定对应的回调方法。关于
AjaxOptions
的配置项讲解,详参Ajax.BeiginForm()知多少

Q39. 什么是Cross Domain AJAX(跨域Ajax)?

Ans. 默认来说,浏览器只允许ajax调用你自己服务器上托管的当前web应用的站点。这个限制帮助组长了许多安全问题(比如XSS攻击)。但是,有些时候我们需要与额外的API(s)交互比如(Twitter或者Google)。因此,为了与额外的API(s)进行交互,我们的web应用就必须支持JSONP请求或CORS(跨域资源分享)。ASP.NET MVC 默认不支持JSONPCORS。如果有这种需要,就需要做一些编码和配置。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: