偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

走進(jìn)ASP.NET MVC 3.0中的Razor模板引擎

開發(fā) 后端
今天我們要討論的是ASP.NET MVC 3.0中的Razor模板引擎,與大家分享關(guān)于Razor的一些感受。

隨著MVC3.0RTM版本的發(fā)布,最近將公司的項(xiàng)目從MVC2.0升級(jí)到MVC3.0。同時(shí)打算在MVC3中全面使用Razor模板引擎?,F(xiàn)將Razor學(xué)習(xí)拿出來(lái)和大家分享,如果存在不足的地方歡迎您指出。

其實(shí)在使用<%= %>在html中調(diào)用C#代碼時(shí),內(nèi)心總在埋怨。這個(gè)寫法非常麻煩。麻煩在哪呢?其實(shí)就是閉合。比如:

Asp.net: <script src="<%=Url.Content("~/Scripts/jquery-1.4.4.min.js")%>"

Razor:   <script src="@Url.Content("~/Scripts/jquery-1.4.4.min.js")" 

非常明顯,Razor在內(nèi)部幫我們做了閉合“%>”。其實(shí)就是這個(gè)小小的閉合讓我們可以在html內(nèi)更加“流暢”的調(diào)用服務(wù)端代碼。故Razor給開發(fā)帶來(lái)了一定的便捷!下面介紹Razor的基本用法。

一、模板頁(yè)

Razor出現(xiàn)后我們就可以選擇不再使用asp.net master 模板頁(yè)。取而代之的是cshtml razor的模板文件。用法個(gè)人認(rèn)為還是和master模板頁(yè)類似。但在mater模板頁(yè)的原有功能上有了進(jìn)一步擴(kuò)展,更方便開發(fā)。比如只要在View文件夾內(nèi)加入_ViewStart.cshtml文件,我們就無(wú)需在每一個(gè)具體的View頁(yè)面引入模板頁(yè)。減少View頁(yè)面內(nèi)的重復(fù)代碼。具體的可以建立一個(gè)MVC3 Application 選擇razor模板,VS會(huì)自動(dòng)建立上述機(jī)制。這里值得提出的是@RenderSection方法??梢宰屛覀?cè)谀0屙?yè)預(yù)設(shè)一個(gè)區(qū)域,未來(lái)給繼承該模板頁(yè)的View使用。具體請(qǐng)看以下操作:

在MVC3.0 shared文件夾下_Layout.cshtml這個(gè)模板文件內(nèi)加入以下代碼:

  1. <!DOCTYPE html>   
  2.  <html>   
  3.  <head>   
  4.    <title>@ViewBag.Title</title>   
  5.   <link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />   
  6.    <script src="@Url.Content("~/Scripts/jquery-1.4.4.min.js")" type="text/javascript"></script>   
  7.   @RenderSection("Head", required: true)   
  8.  </head>   
  9.  <body>   
  10.   <div class="page">  

以上代碼第7行,預(yù)留出一個(gè)Head的section。 熟悉模板頁(yè)的人,應(yīng)該明白該處是預(yù)留是給未來(lái)具體的View頁(yè)面自定義特定js/css使用的。這個(gè)View我們就用默認(rèn)的Home底下的Index來(lái)舉例。打開index.cshtml 寫入以下代碼

  1. @{   
  2.    ViewBag.Title = "Home Page";   
  3. }   
  4. h2>@ViewBag.Message</h2>   
  5. @section Head{   
  6.    <script type="text/javascript">   
  7.     $(function () {   
  8.         alert("hello jquery");   
  9.      });   
  10.    </script>   
  11. }  

該View已經(jīng)集成了模板頁(yè),這里只是填充模板頁(yè)內(nèi)的Head section這時(shí)就可以加入我們的針對(duì)每個(gè)view頁(yè)面的js或者CSS了。至此達(dá)到共性外的個(gè)性。

二、Razor語(yǔ)法:

文章開頭就已經(jīng)提到了,個(gè)人認(rèn)為Razor語(yǔ)法的便捷在于razor自動(dòng)幫助我們閉合C#或VB.NET在html的語(yǔ)法。請(qǐng)看以下代碼:

已經(jīng)給出注釋了,仔細(xì)閱讀并不難理解。您應(yīng)該也能體會(huì)到如果將razor換成asp.net的<%= %>或者<%: %>寫法,其實(shí)是很“痛苦”的。至于razor的其他用法官方網(wǎng)站已經(jīng)寫的很全面了,比如razor的已經(jīng)為我們 HTML Encod防止XSS攻擊、html中字符串中出現(xiàn)×××@×××.com這樣的文本,Razor是可以自動(dòng)識(shí)別成Email格式而不是Razor的關(guān)鍵字。

三、 Razor 語(yǔ)法智能提示:

該智能提示與VS內(nèi)的一樣,只需Ctrol + J 即可調(diào)出。具體的請(qǐng)看下圖

您是否和我一樣也打算在Web開發(fā)中全面使用Razor呢?

原文鏈接:http://www.cnblogs.com/ryanding/archive/2011/01/19/1938690.html

【編輯推薦】

  1. 詳解ASP.NET MVC 3 beta新特性
  2. ASP.NET MVC 3讓依賴注入實(shí)現(xiàn)得更簡(jiǎn)單
  3. 詳解ASP.NET MVC 3 beta新特性
  4. ASP.NET MVC 3新特性與NuPack功能詳解
  5. .NET開發(fā)人員應(yīng)該關(guān)注的七個(gè)開源項(xiàng)目
     
責(zé)任編輯:彭凡 來(lái)源: 博客園
相關(guān)推薦

2010-12-07 09:38:15

ASP.NET MVC

2012-06-26 10:24:51

Asp.Net框架Razor

2021-06-22 16:59:56

微軟.NETC# 軟件開發(fā)

2009-10-09 10:52:43

ASP.NET模板引擎

2009-07-22 13:16:04

MvcAjaxPaneASP.NET MVC

2009-07-24 13:20:44

MVC框架ASP.NET

2009-07-31 12:43:59

ASP.NET MVC

2014-06-30 15:10:32

2009-10-29 09:15:32

ASP.NET MVCDropDownLis

2009-04-08 09:58:07

ASP.NET MVCTempData框架

2009-07-22 10:34:37

ActionInvokASP.NET MVC

2009-07-20 15:44:32

ASP.NET MVC

2009-07-22 09:11:02

Action方法ASP.NET MVC

2009-07-22 13:24:24

ASP.NET MVC

2009-07-22 10:09:59

ASP.NET MVC

2009-07-23 14:31:20

ASP.NET MVC

2009-07-23 15:44:39

ASP.NET MVC

2009-07-20 10:53:59

ASP.NET MVC

2011-09-22 10:58:56

ASP.NET

2011-04-14 09:19:22

ASP.NET MVC
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)