网站快照前显示中文怎么做的,制作二维码软件,中国建设建行网站,信息技术网站建设我的团队当前正在从事的工作之一就是为ASP.NET添加一个新的视图引擎。 一直以来#xff0c;ASP.NET MVC都支持 “视图引擎”的概念—采用不同语法的模板的可插拔模块。当前ASP.NET MVC “默认”的视图引擎是ASP.NET Web窗体使用的.aspx/.ascx/.master文件模板。而当今其他一些…我的团队当前正在从事的工作之一就是为ASP.NET添加一个新的视图引擎。 一直以来ASP.NET MVC都支持 “视图引擎”的概念—采用不同语法的模板的可插拔模块。当前ASP.NET MVC “默认”的视图引擎是ASP.NET Web窗体使用的.aspx/.ascx/.master文件模板。而当今其他一些流行的ASP.NET MVC视图引擎还包括 Spark和 NHaml。 我们正在打造一个新的视图引擎它是一个在HTML生成方面进行优化采用专注于代码的模版解决方案。它的开发代号是“Razor”第一个beta版本很快就会发布出来。 设计目标 在设计和评估“Razor”时我们牢记以下几个目标 · 紧凑、富有表现力和流畅Razor 尽量减少一个文件里需要敲入的字符数给你畅快淋漓的编码体验。与大部分模板的语法不同你不会因为需要在HTML中标注服务器端代码块而中断敲代码的快 感。代码分析器足够聪明能够从你的代码里推断出是否为服务器端代码。这使得其简洁、富有表现力的语法输入能够干净快速有趣。 · 上手快 Razor非常容易上手你只需要了解很少的新东西就可以掌握它使用你现有的编程语言和HTML知识就足够了。 · 不是一个新的编程语言我们尽量避免为Razor创建一个新的命令式语言。相反我们希望让程序员只使用现有的C#/VB或其它编程语言知识就能使用Razor我们只不过在你选择的编程语言里提供一个非常棒的基于模板生成HTML的标记语法。 · 可以使用任何文本编辑器编写Razor不要求什么特别的工具使用老古董的文本编辑器也可以高效编程“记事本”就不错。 · 很好的智能感应输入提示虽然Razor不是专为某个工具或者代码编辑器设计的但它在Visual Studio里还是有很赞的智能提示功能。我们将会升级Visual Studio 2010和Visual Web Developer 2010使得它具有完整的编辑器智能提示功能。 · 便于单元测试新的视图引擎支持对视图执行单元测试不需要控制器controller或者Web服务器而且可以包含在任意的单元测试项目中—不需要单独的应用程序域App-Domain。 过去几个月我们一直在用Razor来编写程序并邀请了一些志愿者包括好几组非.NET的 Web程序员来做易用性研究。使用过它的人对它的评价都不错。 弹性的选择空间 ASP.NET最赞的地方之一就是大部分组件都是可插拔的。如果你发现有一个组件不好用随时都可以换成另外一个。 ASP.NET MVC的下一个版本将会包括一个新的“添加-视图”对话框它让你可以方便地在创建新的视图模板文件时选择你想要使用的语法。它还便于你选择任一个安装在机器上的视图引擎—选择你感觉最自然的视图方案 Razor将会是ASP.NET MVC内置的视图引擎之一。所有的视图辅助helper方法和编程模型特性同时支持Razor和.ASPX视图引擎。 你 还将可以在单个站点或程序中混合使用多个视图引擎写的视图模板。比如说你可以编写一些视图有些用.aspx文件有些用.cshtml或 者.vbhtml文件分别是Razor的C#和VB版本的文件后缀名而另外一些用Spark或者NHaml。你还可以在采用一种视图引擎的视图模板 里包含用另一种引擎编写的局部视图模板。总之你有灵活的选择空间。 Razor版的“Hello World” Razor允许你从静态的HTML页面或者任意的文本内容开始添加服务器端代码使其变成动态页面。Razor的一个核心设计理念就是使编码过程更加流畅并且只要最少的按键次数就能快速地在HTML标记中添加服务器端代码。 让我们来创建一个简单的例子“hello world”它的最终输出如下图所示 使用.ASPX“代码碎块 [ii]”的方式编写 如果用现有ASP.NET的.ASPX标记语法来编写上面的“Hello World”示例的话我们需要在HTML标签中使用”% %”来标记“代码碎块” 仔细观察就可以发现上例中每一个代码碎块都需要5个字符”% %”来标明代码的开始和结束位置。而且其中还有几个字符在键盘上不是特别好敲到特别是“%”键—它位于大部分键盘的中上部。 使用Razor的语法编写 在Razor中你只需要用一个””字符就可以标识代码块的开始与”% %”代码碎块不一样Razor不需要你显式指明代码块的结束位置 Razor分析器懂得代码块中使用的C#或VB的语法—这就是为什么上例中我们不需要显式关闭代码块的原因。Razor可以自动识别出上面的语句是独立的代码块并悄悄地为我们关闭它们。 看看即使是像“hello world”这样微不足道的例子就为我们节省了12次键盘敲击。而且在键盘上””字符还比”%”字符更容易按敲起来更快也更流畅。 循环和内嵌HTML示例 让我们来看看另外一个简单的场景比如说要列出一些商品并在每样商品旁标明价格 用.ASPX”代码碎块”编写 如果用ASP.NET现有的.ASPX标记语法我们可能需要写类似下面的代码来动态生成一个ul列表里面包含表示每个商品的li元素 使用Razor语法 下面是生成同样输出的Razor版本的代码 请 注意上面””符号是如何开始一个“foreach”循环并在循环内嵌入一行包含代码块的HTML语句的。因为Razor分析器知道我们在代码块里用的 C#语法它可以识别出li标签里的内容应该被包含在foreach代码块中并循环处理它们。它甚至还知道末尾的“”结束 foreach循环。 Razor很聪明还能识别出li标签内的p.Name和p.Price是服务器端代码—并且在每次循环时执行它们。另外请留心Razor在HTML和代码混合的情况下还能推导出p.Name和p.Price代码块的结束位置。 不需要在你的模板中添加许许多多打开关闭标记来编写代码的感觉果然是酣畅淋漓。 If代码块和多行语句 下面是其他几个常见的场景 If语句 跟上面的foreach示例一样你可以在if语句中直接嵌入内容或其他C#或者VB语言元素而不需要显式指明代码块的开始和结束位置。例如 多行语句 你可以像下面这样使用“{ 代码 }” 标注多行语句 请注意上例中变量可以被多个代码块引用—变量“message”在包含多行语句的“{}”块中定义但也可以被message代码块使用。这个跟.aspx文件里的”% %”和”% %”的语法类似。 多符号语句 “()”语法允许代码块中有多个符号例如我们可以把上例中连接字符串和数字的代码使用” ()” 代码块这样重写 集成代码和内容 Razor解析器内置了很多语言智能—脏活累活帮你做。 在HTML里它会不会影响””符号在电子邮件地址和其他地方的用法 大部分情况下Razor解析器都有足够的能力推导出模板里的一个“”字符到底是在代码中用到还是在静态内容中用到。例如我在下例中的邮件地址中使用了””字符 当 解析文件时Razor会分析””字符右边的内容来判断它到底是代码如果是CSHTML文件的话那就是C#代码而如果是VBHTML文件的话那就是 VB代码还是静态文本内容。上例中的代码会输出以下的HTML邮件地址被当作静态内容输出而DateTime.Now就被当作代码执行了 如果碰到和代码一样格式的内容或者你想把代码当作内容看待你可以显式地打来用另外一个””字符进行转义。 识别内嵌的内容 当在一个if/elseforeach或者其他块语句中内嵌HTML文本时可以考虑用一个HTML或XML标签将嵌套内容环绕起来这样可以更清楚地标明一个文本内容块的开始。 例如下例我使用span标签包围多行文本内容而文本里还有一个代码块 在客户端的显示结果如下—注意那个span标签 如果你不想在显示文本内容时把外面的标签也输出到客户端那可以考虑使用text将嵌套内容括起来 上面的代码在客户端的输出结果如下—请注意外面的text标签没有被输出 HTML编码 默认情况下””语句块生成的内容会自动对HTML代码进行过滤和转换 [Yimin1] 用来更好地防范XSS垮站脚本攻击。 版面设计/母版页的情况—基础篇 在站点中保持一致的页 面观感风格非常重要。ASP.NET 2.0引入了“母版页面master page”的概念就是用来帮助在使用基于.aspx的页面或模板时实现这个功能。Razor同样也支持这个概念它用的是“版面设计页面 layout pages”—你可以先定义一个通用的站点模板然后在站点其他视图或页面继承模板定义的统一观感。 版面设计的一个简单示例 下 面是一个简单的版面设计页面示例文件将会被保存为“SiteLayout.cshtml”。它包含了所有要放在页面里的静态HTML文本内容和动态的服 务器端代码。接着我们添加了一个名为“RenderBody()”的辅助函数放在模板中需要根据所请求的URL而“填入”具体内容的地方 接下来我们再创建一个名为“Home.cshtml”的视图模板它只包含了必要的文本内容和代码来构成所请求页面的具体内容外围的内容则由版面模板提供 请 留意上面在Home.cshtml文件中我们怎么来显式地设置“LayoutPage”属性。它指明了我们期望用SiteLayout.cshtml作为 这个视图的版面设计模板。我们还可以在ASP.NET MVC 控制器Controller调用Home.cshtml这个视图模板的时候可以指定这个版面设计文件或者将其配置为站点默认的版面设计模板这种 情况下我们只需要在项目中的一个文件中指定它而所有的视图模板都会自动采用它。 当我们将Home.cshtml作为一个视图模板显示时它会合并版面设计页和子页面的内容然后将下面的内容发送到客户端 简洁、清晰、富有表现力的代码 上例中值得注意地方的还有一点就是版面定义和在视图/页面中使用它们的语法既清晰又简练。上面列出的SiteLayout.cshtml和Home.cshtml代码截图已经包含了两个文件所有的代码—没有额外的配置步骤或冗余的标签没有% Page %前缀也不需要设置其它的标签或者属性。 我们尽力使编写出来的代码简洁流畅。我们还希望任何人都可以在一个文本编辑程序中打开、编辑和调整/自定义它们。不需要代码生成或者智能提示Intellisense。 版面设计页面/母版页的情况—覆写部分内容 版面设计页面可以有选择性地定义几个不同的“节”允许基于这个版面设计的视图模板通过“填入”自定义的内容来覆写它。这就允许你在视图中覆写版面设计页里不连续的内容段落从而使你的站点版面设计更有弹性。 例 如我们回到SiteLayout.cshtml文件并在其中定义两个节这样视图模板可以有选择性的填充这两个节。我们将节的名称命名为“menu” 和“footer”—然后在RenderSection()辅助函数传入optionaltrue这个参数来表明它们是可选填充节我们可以用C#最新 的 optional参数语法来做这件事情我在前面的 博客里也提到了这个用法。 因为两个节被标记成了“可选”不需要在Home.cshtml文件中定义它们。即使没有它们站点依然可以正常工作。 让我们回到Home.cshtml并自定义Menu和Footer节。下面的截图包含了Home.cshtml里所有的内容—再没有其它内容了。注我已经把LayoutPage设置为站点范围的默认模板了—所以它没有显示在里面。 我 们覆写的”menu”和“footer”节定义在文件里的以相应的名字命名的section { }块里面。我们刻意不要求你在节里包含“main/body”内容相反将它们内联在页面里除了节省键盘敲击的次数以外还便于你在版面设计页面中添加 新的节以后不需要再回去修改所有已有页面的语法。 当再次将Home.cshtml以视图模板的形式显示的时候它现在会合并版面设计页和子页面里的内容并将两个自定义节覆写的内容整合进来最终发送到客户端的内容如下 封装和重用HTML辅助函数 我们刚刚讲过如何使用版面设计页给站点提供统一的观感。现在让我们看看如何通过创建可复用的“HTML辅助函数”来把生成HTML的功能封装成一个函数库这样可以在整个站点复用—甚至在多个站点复用。 基于代码的HTML辅助函数 ASP.NET MVC有一个“HTML辅助函数”的概念—封装了生成HTML的逻辑并可以用在代码块里的函数。它们当前还都是纯粹通过代码实现的一般通过扩展函数 Extension Method实现。现有的所有内置在ASP.NET MVC里的HTML扩展函数都可以使用在“Razor”视图引擎里不需要修改任何代码 声明式的HTML辅助函数 使用纯代码的类来生成HTML可以工作—但不是很理想。 我们来看Razor的另外一个特性使用简单的更具描述性的方法创建可复用的HTML辅助函数。我们计划让你可以使用类似下面的 helper { }声明式语法创建可复用的辅助函数 你将可以把包含有这种辅助函数的.cshtml文件放到一个Views\Helpers文件夹然后就可以在站点上使用它们了再没有其它的步骤了 请注意上例中我们可以为ProductListing()函数定义参数。这样你就可以为函数传入任意的参数了而且还能完全利用可选参数nullable类型范型等现有编程语言的特性另外还有Visual Studio强大的调试支持。 注helper语法在Razor的第一个beta版里还没有—但我们希望能在下一个发布里把它包含进来。基于代码的辅助函数在第一个Beta版本里就可以使用。 传入内联模板作为参数 Razor中另一个很有用或者可以说是相当了得的功能就是允许向辅助函数传入“内联模板”参数。这些“内联模板”可以同时包含HTML和代码而且可以被辅助函数即行调用。 下例中的“Grid”HTML辅助函数就是通过这种技术在客户端呈现一个DataGrid 上例中Grid.Render()函数调用使用的是C#语法。我们使用了新的语法— C#命名参数把强类型的参数传给Grid.Render函数。这同时也意味着我们可以使用全部智能提示还有编译时的语法检查功能。 在 定义列的时候传给“format”参数的就是一个“内联模板”—它同时包含了自定义的html和代码它们是用来自定义数据的显示方式的。更厉害的 是Grid辅助函数可以把我们的 “内联模板”当作一个委托来调用想几时调用就几时调用想调用多少次就调用多少次。在上面的场景里每呈现grid的一行就会调用它一次—并通过传入 “item”变量以便我们的模板可以显示恰当的内容。 这个功能允许你开发功能更强大的HTML辅助函数。今后你既可以使用代码方式跟现在创建扩展函数的方式一样也可以使用声明式的helper { }方式来编写HTML辅助函数。 对Visual Studio的支持 前面说过Razor的一个目标就是尽量减少键盘敲击次数而且使用普通的文本编辑器就可以编写记事本就很不错了。我们通过保证语法清晰简单干练来实现这个目标。 Visual Studio也支持Razor 使你在里面编写Razor代码时感觉更丰富。对于基于Razor的源文件我们提供了完整的HTML、JavaScript和C#/VB代码智能提示功能 请 注意上面我们甚至为嵌入在foreach循环体里面li元素的Product对象的“p.”启用了智能提示。另外还要注意的地方是 在“解决方案资源管理器”的“\View”文件夹里同时存放了.aspx和.cshtml视图模板。你可以在单个程序中使用多个视图引擎—便于你选择最 适合你的引擎。 总结 我们认为“Razor”是一个非常好的新的视图引擎它提供了流畅的专注于代码的模版方案。它的编码 工作流快速、富有表现力并有趣。语法简练并节省按键次数同时还提升了代码的可读性。它会作为内置的视图引擎并随下一个版本的ASP.NET MVC发布。你也可以把单独的.cshtml/.vbhtml放到程序里并把它们当作独立的页面执行—这样你就也可以在ASP.NETWeb窗体程序中 使用它了。 前几个月里试用过它的开发人员对它的评价都非常好。我们马上就要发布它的第一个beta版并期待收到您对它的反馈。 希望这能对您有所帮助。 【原文地址】 Introducing “Razor” – a new view engine for ASP.NET 【原文发表日期】 July 02, 2010 11:01 PM转载于:https://www.cnblogs.com/X-Jonney/p/4635051.html