1. 程式人生 > >ASP.NET MVC 3: Razor的@:和語法

ASP.NET MVC 3: Razor的@:和語法

代碼塊 新的 涵蓋 解析 for -o mailto ive arch

這是我正在寫的博文系列中的另一篇,涵蓋ASP.NET MVC 3的一些新功能:

http://weblogs.asp.net/scottgu/archive/2010/10/19/asp-net-mvc-3-new-model-directive-support-in-razor.aspxRazor中的布局10月22日)
用Razor實現服務器端註釋(11月12日)
Razor的@:和<syntax>語法(今天)
br/>Razor中的布局10月22日)
用Razor實現服務器端註釋(11月12日)
Razor的@:和<syntax>語法(今天)

用Razor實現流暢編程

ASP.NET MVC 3配有一個新的名為“Razor”的視圖引擎選項(除了已有的.aspx視圖引擎)。您可以在我發表的介紹Razor的博客上了解更多關於Razor的信息,比如我們為什麽要引進它以及 它所支持的語法。

Razor盡量減少編寫一個視圖模板需要敲入的字符數,實現快速流暢的編程工作流。與大部分模板的語法不同,你不必在HTML中為了明確地標記出服務器端語句塊的開始和結束而中斷編程。Razor解析器足夠聰明,能從你的代碼中推斷出來。這樣就使得語法簡潔明了,可以幹凈、快速和有趣地輸入。

例如下面的代碼片段叠代一列商品(product):
技術分享圖片
Razor用來隱式鑒別一個代碼段什麽時候結束的一個方法是尋找代表內容塊開始的標記或元素內容。例如,在上面的代碼段中Razor自動地把foreach循環裏面的<li></li>模塊當作一個HTML內容塊,因為它看到開始的<li>標記序列並且知道這在C#中是無效的。

這個獨特的技術——使用標記來識別代碼中的內容塊——是使Razor在涉及HTML生成的情況下簡潔高效的一個重要因素。

用@明確表示內容的起始

然而不是所有的內容塊都是以標記元開始,在有些案例中,Razor解析器不能隱式檢測出內容塊。

這就需要Razor通過在代碼塊中使用“@:字符序列”來顯式指明內容塊的開始。@:序列表明該行後面的內容應該被視為內容塊:
技術分享圖片
由於我沒有將消息“已售完!”嵌套在HTML標簽元素內,Razor不能隱式判斷@if塊中的內容是否是一個內容塊的開始。我們用“@:字符序列”來明確地指出我們代碼段裏的這行應被當作是內容塊。

在@:內容塊中使用代碼碎塊(Code Nugget)

除了輸出靜態內容,你也可以使代碼碎塊嵌入以@:字符序列開始的內容塊中。

例如,在下面的代碼段中我們有兩個@:字符序列:
技術分享圖片
註意我們在第二個@:序列中如何發送內容塊中的單品(Unit)數目的(例如“只剩下3了!”)。我們通過在內容行中嵌入一個@p.UnitsInStock代碼碎塊來實現。

多行內容

Razor使在HTML元素中包裝多行內容變得簡單。例如,下面我們的@if容器中的內容塊被包裝在一個HTML<p>元素中,這會使得Razor把它當作內容:
技術分享圖片
<text>標簽是一個 Razor 特殊處理的元素。Razor將<text>塊的內部內容視為內容塊,不呈現包含那些內容的<text>標簽(這意味著只呈現<text>內部內容,不呈現標簽本身)。這使呈現沒有被HTML元素包裝的多行內容塊變得方便。

如果你喜歡<text>元素勝過更簡潔的@: 序列,<text>元素也能根據需要用來標識單行內容:
技術分享圖片
總結

Razor啟用了一種簡潔的模板語法,實現非常流暢的編碼工作流。 Razor能靈活地通過檢測<tag>元素來識別內容塊的起始, 從而讓Razor方法在有HTML生成的場景中很有效,也使你在95% 左右的 if/else 和foreach 場景中,不用明顯地標註內容塊的開始/結束.

在當你不想在一個代碼容器塊中使用HTML元素,卻需要更精確地標明一個內容塊的邊界時,你可以使用Razor的@:和<text>語法。

希望這些會有所幫助。

轉載請註明:森大科技官方博客 ? ASP.NET MVC 3: Razor的@:和語法

ASP.NET MVC 3: Razor的@:和語法