成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > ASP.NET預(yù)定義模板介紹

ASP.NET預(yù)定義模板介紹

熱門標(biāo)簽:海東防封電銷卡 云南外呼系統(tǒng)代理 聊城智能電銷機(jī)器人電話 寧德防封版電銷卡 上海市三維地圖標(biāo)注 南昌自動(dòng)外呼系統(tǒng)線路 安陸市地圖標(biāo)注app 西寧電銷外呼系統(tǒng)公司 辦公用地圖標(biāo)注網(wǎng)點(diǎn)怎么操作

一、 實(shí)例演示:通過模板將布爾值顯示為RadioButton

在默認(rèn)的情況下,不論是對(duì)于編輯模式還是顯示模式,一個(gè)布爾類型的屬性值總是以一個(gè)CheckBox的形式呈現(xiàn)出來(lái)。我們創(chuàng)建如下一個(gè)表示員工的類型Employee,它具有一個(gè)布爾類型的屬性IsPartTime表示該員工是否為兼職。

public class Employee 
 { 
 [DisplayName("姓名")] 
 public string Name { get; set; } 
 [DisplayName("部門")] 
 public string Department { get; set; } 
 [DisplayName("是否兼職")] 
 public bool IsPartTime { get; set; } 
} 

如果我們直接調(diào)用HtmlHelperTModel>的EditorForModel方法將一個(gè)Employee對(duì)象顯示在某個(gè)將Employee類型作為Model的強(qiáng)類型View中,下圖體現(xiàn)了默認(rèn)的呈現(xiàn)效果。我們可以看到表示是否為兼職的IsPartTime屬性對(duì)應(yīng)著一個(gè)CheckBox。

現(xiàn)在我們希望的是將所有布爾類型對(duì)象顯示為兩個(gè)RadioButton,具體的顯示效果如下圖所示。那么我們就可以通過創(chuàng)建一個(gè)Model類型為Boolean的View來(lái)創(chuàng)建一個(gè)模板,使之改變所有布爾類型對(duì)象的默認(rèn)呈現(xiàn)效果。

由于我們需要改變的是布爾類型對(duì)象在編輯模式下的呈現(xiàn)形式,所以我們需要將作為模板的分布View定義在EditorTemplates目錄下,這個(gè)目錄可以存在于Views/ Shared下,也可以存在于Views/{ControllerName}下。由于ASP.NET MVC是采用數(shù)據(jù)類型作為匹配條件來(lái)尋找對(duì)應(yīng)的模板的,所以我們需要將分部模板View命名為Boolean。下面的代碼片斷體現(xiàn)了這個(gè)分部試圖的整個(gè)定義,我們通過調(diào)用HtmlHelper的RadioButton方法將兩個(gè)布爾值(True/False)映射為對(duì)應(yīng)的RadioButton,并且采用table>來(lái)布局。

 @model bool 
table> 
 tr> 
 td>@Html.RadioButton("",true,Model)是/td> 
 td>@Html.RadioButton("",false,!Model)否/td> 
 /tr> 
/table> 

值得一提的是,我們沒有指定RadioButton的名稱,而是指定一個(gè)空字符串,Html本身會(huì)對(duì)其進(jìn)行命名,而命名的依據(jù)就是本章介紹的核心:Model元數(shù)據(jù)。Employee的IspartTime屬性呈現(xiàn)在界面上對(duì)應(yīng)的HTML如下所示,我們可以看到兩個(gè)類型為radio的input>元素的name被自動(dòng)賦上了對(duì)應(yīng)的屬性名稱。美中不足的是它們具有相同的ID,如果希望讓ID具有唯一性,可以對(duì)模板進(jìn)行更加細(xì)致的定制。

div class="editor-label">label for="IsPartTime">是否兼職/label>/div> 
div class="editor-field"> 
 table> 
 tr> 
 td>input checked="checked" id="IsPartTime" name="IsPartTime" type="radio" value="True" .../>是/td> 
 td>input id="IsPartTime" name="IsPartTime" type="radio" value="False" />否/td> 
 /tr> 
 /table> 
/div> 

二、預(yù)定義模板

上面我們介紹如何通過View的方式創(chuàng)建模板進(jìn)而控制某種數(shù)據(jù)類型或者某個(gè)目標(biāo)元素最終在UI界面上的HTML呈現(xiàn)方式,實(shí)際上在ASP.NET MVC的內(nèi)部還定義了一系列的預(yù)定義模板。當(dāng)我們調(diào)用HtmlHelper/HtmlHelperTModel>的模板方法對(duì)Model或者M(jìn)odel的某個(gè)成員進(jìn)行呈現(xiàn)的時(shí)候,系統(tǒng)會(huì)根據(jù)當(dāng)前的呈現(xiàn)模式(顯示模式和編輯模式)和Model元數(shù)據(jù)獲取一個(gè)具體的模板(自定義模版或者預(yù)定義模版)。由于Model具有顯示和編輯兩種呈現(xiàn)模式,所以定義在ASP.NET MVC內(nèi)部的默認(rèn)模版分為這兩種基本的類型。接下來(lái)我們就逐個(gè)介紹這些預(yù)定義模版以及最終的HTML呈現(xiàn)方式。

EmailAddress
該模板專門針對(duì)用于表示Email地址的字符串類型的數(shù)據(jù)成員,它將目標(biāo)元素呈現(xiàn)為一個(gè)href屬性具有“mailto:”前綴的鏈接(a>/a>)。由于該模板僅僅用于Email地址的顯示,所以只在顯示模式下有效,或者說ASP.NET MVC僅僅定義了基于顯示模式的EmailAddress模板。為了演示數(shù)據(jù)在不同模板下的呈現(xiàn)方式,我們定義了如下一個(gè)簡(jiǎn)單的數(shù)據(jù)類型Model,我們通過在屬性Foo上應(yīng)用UIHintAttribute特性將模板名稱設(shè)置為“EmailAddress”。

public class Model 
{ 
 [UIHint("EmailAddress")] 
 public string Foo { get; set; } 
} 

然后在一個(gè)基于Model類型的強(qiáng)類型View中,我們通過調(diào)用HtmlHelperTModel>的DisplayFor方法將一個(gè)具體的Model對(duì)象的Foo屬性以顯示模式呈現(xiàn)出來(lái)。

@model Model 
@Html.DisplayFor(m=>m.Foo) 

如下的代碼片斷表示Model的Foo屬性對(duì)應(yīng)的HTML,我們可以看到它就是一個(gè)針對(duì)Email地址的連接。當(dāng)我們點(diǎn)擊該鏈接的時(shí)候,相應(yīng)的Email編輯軟件(比如Outlook)會(huì)被開啟用于針對(duì)目標(biāo)Email地址的郵件編輯。

a href="mailto:foo@gmail.com">foo@gmail.com/a> 

HiddenInput
關(guān)于默認(rèn)模板HiddenInput我們不應(yīng)該感到模式,前面介紹的HiddenInputAttribute特性就是將表示Model元數(shù)據(jù)的ModelMetadata對(duì)象的TemplateHint屬性設(shè)置為HiddenInput。如果目標(biāo)元素采用HiddenInput模板,在顯示模式下內(nèi)容會(huì)以文本的形式顯示;編輯模式下不僅會(huì)以文本的方式顯示其內(nèi)容,還會(huì)生成一個(gè)對(duì)應(yīng)的type屬性為“hidden”的input>元素。如果表示Model元數(shù)據(jù)的ModelMetadata對(duì)象的HideSurroundingHtml屬性為True(將應(yīng)用在目標(biāo)元素上的特性HiddenInputAttribute的DisplayValue屬性設(shè)置為False),不論是顯示模式還是編輯模式下顯示的文本都將消失。

同樣以上面定義的數(shù)據(jù)類型Model為例,我們通過在Foo屬性上應(yīng)用UIHintAttribute特性將模板名稱設(shè)置為“HiddenInput”。

public class Model 
{ 
 [UIHint("HiddenInput")] 
 public string Foo { get; set; } 
 public bool Bar { get; set; } 
 public decimal Baz { get; set; } 
} 

然后在一個(gè)基于Model類型的強(qiáng)類型View中分別調(diào)用HtmlHelperTModel>的DisplayFor和EditFor方法將一個(gè)具體的Model對(duì)象的Foo屬性以顯示和編輯模式呈現(xiàn)出來(lái)。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.EditorFor(m=>m.Foo) 

分別以兩種模式呈現(xiàn)出來(lái)的Foo屬性對(duì)應(yīng)的HTML如下(包含在花括號(hào)中的GUID表示屬性值)。第一行是針對(duì)顯示模式的,可以看出最終呈現(xiàn)出來(lái)僅限于表示屬性值得文本;而編輯模式對(duì)應(yīng)的HTML中不僅包含屬性值文本,還具有一個(gè)對(duì)應(yīng)的類型為“hidden”的input>元素。

{42A1E9B7-2AED-4C8E-AB55-78813FC8C233} 
{42A1E9B7-2AED-4C8E-AB55-78813FC8C233}input id="Foo" name="Foo" type="hidden" value="{42A1E9B7-2AED-4C8E-AB55-78813FC8C233}" /> 

現(xiàn)在我們對(duì)數(shù)據(jù)類型Model做一下簡(jiǎn)單修改,將應(yīng)用在屬性Foo上的UIHintAttribute特性替換成HiddenInputAttribute特性,并將其DisplayValue屬性設(shè)置成False。

public class Model 
{ 
 [HiddenInput(DisplayValue = false)] 
 public string Foo { get; set; } 
 public bool Bar { get; set; } 
 public decimal Baz { get; set; } 
} 

由于應(yīng)用在目標(biāo)元素上的HiddenInputAttribute特新的DisplayValue屬性會(huì)最終控制對(duì)應(yīng)ModelMetadata的HideSurroundingHtml屬性,而后者控制是否需要生成用于顯示目標(biāo)內(nèi)容的HTML。所以針對(duì)針對(duì)的Model定義,最終會(huì)生成如下一段HTML。

input id="Foo" name="Foo" type="hidden" value="{42A1E9B7-2AED-4C8E-AB55-78813FC8C233}" /> 

Html

如果目標(biāo)對(duì)象的內(nèi)容包含一些HTML,并需要在UI界面中原樣呈現(xiàn)出來(lái),我們可以采用Html模板。和EmailAddress模板一樣,該模板僅限于顯示模式。為了演示Html模板對(duì)目標(biāo)內(nèi)容的呈現(xiàn)方法與默認(rèn)呈現(xiàn)方式之間的差異,我們定義了如下一個(gè)數(shù)據(jù)類型Model。該數(shù)據(jù)類型具有兩個(gè)字符串類型的屬性Foo和Bar,其中Foo上面應(yīng)用UIHintAttribute特性將模板名稱設(shè)置為“Html”。

public class Model 
{ 
 [UIHint("Html")] 
 public string Foo { get; set; } 
 public string Bar { get; set; } 
}

現(xiàn)在我們創(chuàng)建一個(gè)具體的Model對(duì)象,并將Foo和Bar設(shè)置為一段表示鏈接的文本(a href="www.google.com">google.com/a>),最終在一個(gè)基于Model類型的強(qiáng)類型View中通過調(diào)用HtmlHelperTModel>的DisplayFor方法將這兩個(gè)屬性以顯示模式呈現(xiàn)出來(lái)。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.DisplayFor(m => m.Bar) 

從如下所示的表示Foo和Bar兩屬性的HTML中我們不難看出:采用Html模板的Foo屬性的內(nèi)容原樣輸出,而包含在屬性Bar中的HTML都進(jìn)行了相應(yīng)的編碼。

a href="www.google.com">google.com/a> lt;a href=quot;www.google.comquot;gt;google.comlt;/agt; 

Text與String

不論是在顯示模式還是編輯模式,Text和String模板具有相同的HTML呈現(xiàn)方式(實(shí)際上在ASP.NET MVC內(nèi)部,兩種模版最終生成的HTML是通過相同的方法產(chǎn)生的)。對(duì)于這兩種模版來(lái)說,目標(biāo)內(nèi)容在顯示模式下直接以文本的形式輸出;而在編輯模式下則對(duì)應(yīng)著一個(gè)單行的文本框。

為了演示兩種模版的同一性,我們對(duì)上面定義數(shù)據(jù)類型Model略作修改,在屬性Foo和Bar上應(yīng)用UIHintAttribute特性并將模版名稱分別設(shè)置為String和Text。

public class Model 
{ 
 [UIHint("String")] 
 public string Foo { get; set; } 
 [UIHint("Text")] 
 public string Bar { get; set; } 
} 

然后我們創(chuàng)建一個(gè)具體的Model對(duì)象,并在一個(gè)基于該Model類型的強(qiáng)類型View中通過調(diào)用HtmlHelperTModel>的DisplayFor和EditorFor將兩個(gè)屬性分別以顯示和編輯模式呈現(xiàn)出來(lái)。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.DisplayFor(m => m.Bar) 
@Html.EditorFor(m=>m.Foo) 
@Html.EditorFor(m => m.Bar) 

如下所示的代碼片斷體現(xiàn)了上述四個(gè)元素對(duì)應(yīng)的HTML(“Dummy text …”是Foo和Bar的屬性值),可以看到采用了Text和String模板的兩個(gè)屬性在顯示和編輯模式下具有相同的呈現(xiàn)方式。編輯模式下輸出的類型為“text”的input>元素表示CSS特性類型的class屬性被設(shè)置為“text-box single-line”,意味著這是一個(gè)基于單行的文本框。

Dummy text ... 
Dummy text ... 
input class="text-box single-line" id="Foo" name="Foo" type="text" value="Dummy text ..." /> 
input class="text-box single-line" id="Bar" name="Bar" type="text" value="Dummy text ..." /> 

值得一提的是,ASP.NET MVC內(nèi)部采用基于類型的模板匹配機(jī)制,對(duì)于字符串類型的數(shù)據(jù)成員,如果沒有顯式設(shè)置采用的模板名稱,默認(rèn)情況下會(huì)采用String模板。

Url

與EmailAddress和Html一樣,模板Url也僅限于顯示模式。對(duì)于某個(gè)表示為Url的字符串,如果我們希望它最終以一個(gè)連接的方式呈現(xiàn)在最終生成的HTML中,我們采用該模板。如下面的代碼片斷所示,我們通過應(yīng)用UIHintAttribute特性將模板Url應(yīng)用到屬性Foo中。

public class Model 
{ 
 [UIHint("Url")] 
 public string Foo { get; set; } 
} 

我們創(chuàng)建一個(gè)具體的Model對(duì)象,并將Foo屬性設(shè)置為一個(gè)表示Url的字符串“http://www.asp.net”,最后通過如下的方式將該屬性以顯示模式呈現(xiàn)出來(lái)。

@model Model 
@Html.DisplayFor(m=>m.Foo) 

如下面的代碼片斷所示,該屬性最終呈現(xiàn)為一個(gè)href屬性和文本內(nèi)容均屬性值得連接(a>/a>)。

a >http://www.asp.net/a> 

 
MultilineText
一般的字符串在編輯模式下會(huì)呈現(xiàn)為一個(gè)單行的文本框(類型為“text”的input>元素),而MultilineText模板會(huì)將表示目標(biāo)內(nèi)容的字符串通過一個(gè)textarea>元素,該模板僅限于編輯模式。如下面的的代碼片斷所示,我們通過在字符串類型的Foo屬性上應(yīng)用UIHintAttribute特性將應(yīng)用的模板設(shè)置為MultilineText。

public class Model 
{ 
 [UIHint("MultilineText")] 
 public string Foo { get; set; } 
} 

現(xiàn)在我們創(chuàng)建一個(gè)具體的Model對(duì)象并通過如下的形式將Foo屬性以編輯模式呈現(xiàn)在某個(gè)基于Model類型的強(qiáng)類型View中。

@model Model 
@Html.EditorFor(m=>m.Foo) 

如下所示的代碼片斷表示Model的Foo屬性呈現(xiàn)在UI界面中的HTML(“dummy text …”是是Foo的屬性值),我們可以看到這是一個(gè) textarea >元素。表示CSS樣式類型的class屬性被設(shè)置為“text-box multi-line”,意味著它是以多行的效果呈現(xiàn)。

textarea class="text-box multi-line" id="Foo" name="Foo">dummy text .../textarea> 

Password

對(duì)于表示密碼字符串來(lái)說,在編輯模式下應(yīng)該呈現(xiàn)為一個(gè)類型為“password”的input>元素,使我們輸入的內(nèi)容以掩碼的形式顯示出來(lái)以保護(hù)密碼的安全性。在這種情況下我們可以采用Password模板,該模板和MultilineText一樣也僅限于編輯模式。如下面的代碼片斷所示,我們?cè)贛odel的Foo屬性上應(yīng)用UIHintAttribute特性將模式名稱設(shè)置為“Password”。

public class Model 
{ 
 [UIHint("Password")] 
 public string Foo { get; set; } 
} 

我們創(chuàng)建一個(gè)具體的Model對(duì)象,并通過如下的形式將Foo屬性以編輯模式呈現(xiàn)在某個(gè)基于Model的強(qiáng)類型View中。

@model Model 
@Html.EditorFor(m=>m.Foo) 

該Foo屬性最終會(huì)以如下的形式通過一個(gè)類型為“Password”的input>元素呈現(xiàn)出來(lái),表示CSS樣式類型的class屬性被設(shè)置為“text-box single-line password”,意味著呈現(xiàn)效果為一個(gè)單行的文本框。

input class="text-box single-line password" id="Foo" name="Foo" type="password" value="" /> 

Decimal

如果采用Decimal模板,代表目標(biāo)元素的數(shù)字不論其小數(shù)位數(shù)是多少,都會(huì)最終被格式化為兩位小數(shù)。在顯示模式下,被格式化的數(shù)字直接以文本的形式呈現(xiàn)出來(lái);在編輯模式下則對(duì)應(yīng)著一個(gè)單行的文本框架。如下面的代碼片斷所示,我們?cè)跀?shù)據(jù)類型Model中定義了兩個(gè)對(duì)象類型屬性Foo和Bar,上面應(yīng)用了UIHintAttribute特性并將模板名稱指定為“Decimal”。

public class Model 
{ 
 [UIHint("Decimal")] 
 public object Foo { get; set; } 
 [UIHint("Decimal")] 
 public object Bar { get; set; } 
} 

我們創(chuàng)建一個(gè)具體的Model對(duì)象,將它的Foo和屬性分別設(shè)置為整數(shù)123和浮點(diǎn)數(shù)3.1415(4位小數(shù)),最終通過如下的形式將它們以顯示和編輯的模式呈現(xiàn)在一個(gè)基于Model類型的強(qiáng)類型View中。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.DisplayFor(m=>m.Bar) 
@Html.EditorFor(m=>m.Foo) 
@Html.EditorFor(m =>m.Bar) 

上述四個(gè)元素在最終呈現(xiàn)的UI界面中對(duì)應(yīng)著如下的HTML,我們可以看到最終顯示的都是具有兩位小數(shù)的數(shù)字。

123.00 
3.14 
input class="text-box single-line" id="Foo" name="Foo" type="text" value="123.00" /> 
input class="text-box single-line" id="Bar" name="Bar" type="text" value="3.14" /> 

Boolean

通過本章最開始的實(shí)例演示我們知道一個(gè)布爾類型的對(duì)象在編輯模式下會(huì)以一個(gè)類型為“checkbox”的input>元素的形式呈現(xiàn),實(shí)際上在顯示模式下它依然對(duì)應(yīng)著這么一個(gè)元素,只是其disabled屬性會(huì)被設(shè)置為True使之處于只讀狀態(tài)。布爾類型的這種默認(rèn)呈現(xiàn)方式源自“Boolean”模板默認(rèn)被使用。

當(dāng)布爾類的目標(biāo)元素以編輯模式進(jìn)行呈現(xiàn)的時(shí)候,除了生成一個(gè)一個(gè)類型為“checkbox”的input>元素之外還會(huì)附加產(chǎn)生一個(gè)類型為“hidden”的input>元素。如下面的代碼片斷所示,這個(gè)hidden元素具有與CheckBox相同的名稱,但是值為False,它存在的目的在于當(dāng)CheckBox沒有被勾選的情況下通過對(duì)應(yīng)的hidden元素向服務(wù)區(qū)提交相應(yīng)的值(False),因?yàn)闆]有被勾選的CheckBox的值是不會(huì)包含在請(qǐng)求中的。

input id="Foo" name="Foo" type="checkbox" value="true" /> 
input name="Foo" type="hidden" value="false" /> 

Boolean和String、Decimal以及后面我們介紹的Object一樣屬于是基于CLR類型的模板。由于ASP.NET在內(nèi)部采用基于類型的模板匹配策略,如果沒有顯示設(shè)置采用的模板類型,相應(yīng)類型的元素會(huì)默認(rèn)采用與之匹配的模板。

Collection

顧名思義,Collection模板用于集合類型的目標(biāo)元素的顯示與編輯。對(duì)應(yīng)采用該模板的類型為集合(實(shí)現(xiàn)了IEnumerable接口)的目標(biāo)元素,在調(diào)用HtmlHelper或者HtmlHelperTModel>以顯示或者編輯模式對(duì)其進(jìn)行呈現(xiàn)的時(shí)候,會(huì)遍歷其中的每個(gè)元素,并根據(jù)基于集合元素的Model元數(shù)據(jù)決定對(duì)其的呈現(xiàn)方法。同樣一我們定義的數(shù)據(jù)類型Model為例,我們按照如下的方式將它的Foo屬性類型改為對(duì)象數(shù)組,上面應(yīng)用了UIHintAttribute特性并將模板名稱 設(shè)置為“Collection”。

public class Model 
{ 
 [UIHint("Collection")] 
 public object[] Foo { get; set; } 
} 

然后按照下面的方式創(chuàng)建一個(gè)包含三個(gè)對(duì)象的數(shù)組,作為數(shù)據(jù)元素的三個(gè)對(duì)象類型為別是數(shù)字、字符串和布爾,然后將該數(shù)組作為Foo屬性創(chuàng)建一個(gè)具體的Model對(duì)象。

object[] foo = new object[] 
{ 
 123.00, 
 "dummy text ...", 
 true 
}; 
Model model = new Model { Foo = foo }; 

在一個(gè)基于Model類型的強(qiáng)類型View中,我們分別調(diào)用HtmlHelperTModel>的DisplayFor和EditorFor方法將上面創(chuàng)建的Model對(duì)象的Foo屬性以顯示和編輯模式呈現(xiàn)出來(lái)。

@model Model 
@Html.DisplayFor(m=>m.Foo) 
@Html.EditorFor(m=>m.Foo) 

Model對(duì)象的Foo屬性最終呈現(xiàn)出來(lái)的HTML如下所示,我們可以看到不論是顯示模式還是編輯模式,基本上就是對(duì)集合元素呈現(xiàn)的HTML的組合而已。

123dummy text ...input checked="checked" class="check-box" disabled="disabled" type="checkbox" /> 
input class="text-box single-line" data-val="true" data-val-number="The field Double must be a number." data-val-required="The Double field is required." id="Foo_0_" name="Foo[0]" type="text" value="123" /> 
input class="text-box single-line" id="Foo_1_" name="Foo[1]" type="text" value="dummy text ..." /> 
input checked="checked" class="check-box" data-val="true" data-val-required="The Boolean field is required." id="Foo_2_" name="Foo[2]" type="checkbox" value="true" /> 
input name="Foo[2]" type="hidden" value="false" /> 
Object

我們說過,ASP.NET 內(nèi)部采用基于類型的模板匹配策略,如果通過ModelMetadata對(duì)象表示的Model元數(shù)據(jù)不能找到一個(gè)具體的模板,最終都會(huì)落到Object模板上。Object模板對(duì)目標(biāo)對(duì)象的呈現(xiàn)方式很簡(jiǎn)單,它通過ModelMetadata的Proeprties屬性得到所有基于屬性的Model元數(shù)據(jù)。針對(duì)每個(gè)表示屬性Model元數(shù)據(jù)的ModelMetadata,它會(huì)根據(jù)DisplayName或者屬性名稱生成一個(gè)標(biāo)簽(實(shí)際上是一個(gè)內(nèi)部文本為顯示名稱的div>元素),然后根據(jù)元數(shù)據(jù)將屬性值以顯示或者編輯的模式呈現(xiàn)出來(lái)。

 public class Address 
 { 
 [DisplayName("省")] 
 public string Province { get; set; } 
 [DisplayName("市")] 
 public string City { get; set; } 
 [DisplayName("區(qū)")] 
 public string District { get; set; } 
 [DisplayName("街道")] 
 public string Street { get; set; } 
} 

針對(duì)上面定義得這個(gè)表示地址的Address?,F(xiàn)在我們創(chuàng)建一個(gè)具體的Address對(duì)象并通過如下的方式調(diào)用HtmlHelperTModel>的DisplayForModel方法將它呈現(xiàn)在以此作為Model的View中。

@model Address 
@Html.DisplayForModel() 

從如下所示的HTML中我們可以看出作為Model的Address對(duì)象的所有屬性都以顯示模式呈現(xiàn)出來(lái),而在前面還具有相應(yīng)的標(biāo)簽。

div class="display-label">省/div> 
div class="display-field">江蘇省/div> 
div class="display-label">市/div> 
div class="display-field">蘇州市/div> 
div class="display-label">區(qū)/div> 
div class="display-field">工業(yè)園區(qū)/div> 
div class="display-label">街道/div> 
div class="display-field">星湖街328號(hào)/div> 

值得一提的是,Object模板在對(duì)屬性進(jìn)行遍歷的過程中,不論是顯示模式還是編輯模式,只會(huì)處理非復(fù)雜類型。也就是如果屬性成員是一個(gè)復(fù)雜類型(不能支持從字符串類型的轉(zhuǎn)換),它不會(huì)出現(xiàn)在最終生成的HTML中。

 public class Contact 
 { 
 [DisplayName("姓名")] 
 public string Name { get; set; } 
 [DisplayName("電話")] 
 public string PhoneNo { get; set; } 
 [DisplayName("Email地址")] 
 public string EmailAddress { get; set; } 
 [DisplayName("聯(lián)系地址")] 
 public Address Address { get; set; } 
} 

通過上面的代碼片斷,我們定義了一個(gè)表示聯(lián)系人的數(shù)據(jù)類型Contact,它具有一個(gè)類型的Address的同名屬性。現(xiàn)在我們創(chuàng)建一個(gè)具體的Contact對(duì)象,并 對(duì)包括Address 屬性在內(nèi)的所有屬性進(jìn)行初始化,然后通過如下的方式通過調(diào)用HtmlHelperTModel>的DisplayForModel方法將它呈現(xiàn)在以此作為Model的View中。

@model Contact 
@Html.DisplayForModel() 

從如下所示的HTML可以看出,Contact的數(shù)據(jù)成員Address由于是復(fù)雜類型,其內(nèi)容并不會(huì)呈現(xiàn)出來(lái)。

div class="display-label">姓名/div> 
div class="display-field">張三/div> 
div class="display-label">電話/div> 
div class="display-field">1234567890/div> 
div class="display-label">Email地址/div> 
div class="display-field">zhangsan@gmail.com/div> 

我們可以有兩種方式解決這個(gè)問題,其實(shí)就是通過為Address類型定義各類專門的模板用于地址信息的顯示和編輯,通過UIHintAttribute特性將此模板名稱應(yīng)用到Contact的Address屬性上,然后調(diào)用DisplayFor/EditorFor將該屬性呈現(xiàn)出來(lái)。另一種就是按照類似如如下的方式手工將負(fù)責(zé)類型屬性成員呈現(xiàn)出來(lái)。

@model Contact 
@Html.DisplayForModel() 
div class="display-label">@Html.DisplayName("Address")/div> 
div class="display-field">@(Model.Address.Province + Model.Address.City + Model.Address.District+ Model.Address.Street)/div>

以上就是關(guān)于ASP.NET預(yù)定義模板介紹,希望對(duì)大家的學(xué)習(xí)有所幫助。

您可能感興趣的文章:
  • ASP.NET中實(shí)現(xiàn)模板頁(yè)
  • asp.net TemplateField模板中的Bind方法和Eval方法
  • asp.net GridView控件中模板列CheckBox全選、反選、取消
  • asp.net(C#)壓縮圖片,可以指定圖片模板高寬
  • asp.net GridView模板列中實(shí)現(xiàn)選擇行功能
  • asp.net下將頁(yè)面內(nèi)容導(dǎo)入到word模板中的方法
  • 使用ASP.NET模板生成HTML靜態(tài)頁(yè)面的五種方案
  • asp.net 按指定模板導(dǎo)出word,pdf實(shí)例代碼
  • asp.net使用npoi讀取excel模板并導(dǎo)出下載詳解
  • ASP.NET網(wǎng)站模板的實(shí)現(xiàn)(第2節(jié))

標(biāo)簽:衢州 青海 洛陽(yáng) 汕尾 贛州 崇左 南寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP.NET預(yù)定義模板介紹》,本文關(guān)鍵詞  ASP.NET,預(yù),定義,模板,介紹,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ASP.NET預(yù)定義模板介紹》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于ASP.NET預(yù)定義模板介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    97久久精品人人澡人人爽缅北| 日韩精品中文字幕一区二区| 国产精品亚洲一区二区三区在线观看| 8mav在线| 精品久久久久久久久久久院品网| 亚洲免费观看高清完整| 欧美图片欧美激情欧美精品| aaa人片在线| 2020av在线| 久久香蕉综合色一综合色88| 欧美成人精品不卡视频在线观看| 一区二区三区产品免费精品久久75| 日本电影亚洲天堂一区| 不卡免费追剧大全电视剧网站| 日韩三区四区| 亚洲a视频在线观看| 久久久久久久久久久久国产| 亚洲欧美日韩成人| 一区二区三区欧美成人| 一本久久a久久精品亚洲| 一本岛在免费一二三区| 国产精品资源网| 精品日韩一区二区三区免费视频| 国产网站观看9久| 久久久777| h视频免费高清在线观看| 天堂va蜜桃一区二区三区漫画版| 99久久久免费精品国产一区二区| 欧美日韩色一区| 成人涩涩免费视频| 黄色av免费在线播放| 视频一区欧美日韩| www视频在线看| 国产在线视频一区二区| 成人黄色综合网站| 国产精品视频久久久久久久| 免费在线看污片| 国产人成一区二区三区影院| 国产精品人成电影在线观看| 最好看的日本字幕mv视频大全| 97欧美精品一区二区三区| 欧美精品一区二区三区中文字幕| 日韩一级二级三级精品视频| 免费三级网站| 欧美色欧美色| 亚洲黄一区二区三区| 日韩精品一区二区三区老鸭窝| 最新地址在线观看| 一级 黄 色 片一| 亚洲日本在线播放| 在线精品视频一区| 国产中文字字幕乱码无限| 免费亚洲电影| 色播视频在线观看| 国产又黄又爽又无遮挡| 天天操天天操天天| 久久天堂成人| 国产在线精品观看| 亚洲欧美日韩天堂| 亚洲手机在线| 久久久久久久999精品视频| 亚洲的天堂在线中文字幕| 国产丝袜在线观看视频| 99精品99久久久久久宅男| 久久久久九九视频| 黄色在线观看www| 91在线看视频| 2019日韩中文字幕mv| 精品人妻久久久久一区二区三区| 亚洲精品怡红院| 蜜臀在线观看| 久久精品www人人爽人人| 精品国产一二三四区| 日本十八禁视频无遮挡| 色偷偷888欧美精品久久久| 伊人夜夜躁av伊人久久| 播播国产欧美激情| 大片免费在线看视频| 久久爱91午夜羞羞| 日韩午夜电影| 波多野结衣手机在线视频| 久热这里只精品99re8久| 日本福利午夜视频在线| 国产福利一区二区三区视频在线| 国产精品九九九| 久久久久综合网| 亚洲第一福利专区| 人妻少妇精品久久| 欧美中文字幕第一页| 国产欧美日韩视频一区二区| 尤物av无码色av无码| 老鸭窝91久久精品色噜噜导演| 亚洲视频欧美视频| 欧美日韩国产综合视频在线观看中文| 成人av网站大全| 成人午夜短视频| 国产成人涩涩涩视频在线观看| 日韩国产欧美一区二区| 国产成人av电影免费在线观看| 霍思燕三级露全乳照| 久久综合五月天| 精品国产精品国产偷麻豆| 国产精品一区二三区| av男人的天堂网| 亚洲国产高清自拍| 日本国产在线播放| 午夜免费入口| 欧美又大又粗又长| 亚洲欧洲色图综合| 91九色丨porny丨肉丝| 成人黄色生活片| 白嫩情侣偷拍呻吟刺激| 一区精品在线观看| 天天躁日日躁狠狠躁超碰2020| 嫩草嫩草嫩草嫩草| 日韩一本二本av| 久久精品视频免费观看| 99国内精品久久久久久久软件| 日韩国产精品毛片| 欧美二区在线| 免费视频一二三区| 欧洲性视频在线播放| 欧美亚洲色综久久精品国产| 久久久久无码精品国产sm果冻| 麻豆久久久久| 国产高清在线| 影视先锋久久| 香港成人在线视频| 成年大片免费视频播放二级| 少妇人妻丰满做爰xxx| 一本色道久久88亚洲综合88| 一个色在线视频| 国产成人精品亚洲线观看| 99热在线这里只有精品| 国产精品欧美亚洲777777| 天天干在线影院| 亚洲精品资源美女情侣酒店| 韩国av电影在线观看| 五月天婷婷激情视频| 欧美综合自拍| 精品国产免费人成电影在线观看四季| xxxxhd欧美精品| 中文字幕人妻一区二区三区| 亚洲国产精品123| 亚洲综合一区二区精品导航| 国产精品1区2区3区在线观看| 精品一区二区三区蜜桃| 亚洲精品乱码久久久久久按摩观| 美女诱惑一区| 可以免费在线看黄的网站| 中文精品99久久国产香蕉| 国产最新视频在线| 在线观看黄色av网站| 欧美人与动性xxxxx杂性| 草草草在线视频| 亚洲国产精品v| 五月天丁香激情| 亚洲精品日韩成人| 午夜在线成人av| 国产欧美一区二区三区另类精品| 国产乱子夫妻xx黑人xyx真爽| 免费下载黄色软件| 国产午夜精品美女毛片视频| 精品在线一区| 91福利视频网站| 国产一区二区三区亚洲综合| 成人免费高清在线| 男人天堂资源网| 亚洲精品视频二区| 欧美成人h版在线观看| 亚洲丝袜一区在线| 免费一级欧美片在线观看网站| 真实国产乱子伦对白在线| 岛国av一区二区在线在线观看| 黄色片免费在线观看视频| 亚洲国产综合在线看不卡| 黄色成人羞羞视频| 成人在线观看毛片| 欧美一区二区三区在线观看免费| 亚洲欧美一区二区三区孕妇| 婷婷激情5月天| 成人在线免费观看网站| 男女精品网站| 亚洲 小说 欧美 激情 另类| 日韩欧美精品一区| 91免费观看| 久久精品论坛| 91精品啪在线观看国产| 亚洲精品免费一区二区三区| 制服丝袜中文字幕一区| 国产中文字幕一区| 97精品97| 神马久久久久久久久| 国产一区一一区高清不卡| 亚洲美女福利视频网站| 男人天堂免费视频| 精品福利视频一区二区三区| 女人18毛片毛片毛片毛片区二| 一道精品一区二区三区| 中文字幕在线视频观看| 日本一级黄视频| 99久久婷婷国产综合精品电影| 亚洲精选在线观看| 黑人性受xxxx黑人xyx性爽| 免费网站在线观看视频| 97国产超碰| 波多野结衣视频免费观看| 亚洲激情专区| 99精品一级欧美片免费播放| 久久激五月天综合精品| 欧美日韩亚洲综合一区二区三区激情在线| 国产精品冒白浆免费视频| 夜夜躁狠狠躁日日躁婷婷小说| 国产一区二区三区不卡视频网站| 国产精品手机在线| 里番全彩acg☆无翼乌全彩3d| 成人网在线视频| 美国av免费观看| 成人影视免费观看| 久久成人综合| 夜夜嗨av一区二区三区| 99久久婷婷国产综合精品| 毛片av在线播放| 中文字幕在线观看第三页| 精品高清一区二区三区| 欧美a级大片在线| 婷婷综合伊人| 欧美性xxxxx极品娇小| 国产女人精品视频| 99在线视频观看| 一炮成瘾1v1高h| 久草视频在线看| 国产成人精品综合网站| 全球中文成人在线| 国产精品av免费在线观看| аⅴ资源新版在线天堂| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲精品观看| 最近2019年中文视频免费在线观看| 老司机精品福利视频| 久久精品国产精品亚洲| 日韩欧美亚洲v片| 久久网站免费视频| 久久久老熟女一区二区三区91| 亚洲欧美日韩天堂| 久久国产精品久久精品国产| 男操女在线观看| 正义之心1992免费观看全集完整版| 欧美精品一区二区在线观看| 国产一区二区三区四区五区加勒比| 亚洲欧洲高清| av在线播放一区二区三区| 亚洲欧美一区二区精品久久久| 亚洲一区自拍偷拍| av播放在线观看| 麻豆传媒在线看| 国产一区二区自拍视频| 国产欧美日韩麻豆91| 波多野结衣办公室33分钟| 亚洲精品乱码久久久久久蜜桃动漫| 亚洲国产成人无码av在线| 日韩国产欧美精品| 亚洲精品在线播放视频| 欧美日韩专区| 国产又大又黑又粗免费视频| 男女激情免费视频| 国产伦精品一区二区三区免费视频| 欧亚av在线| www.26天天久久天堂| 在线观看一级片| 国产精品偷伦免费视频观看的| 视频一区二区三区中文字幕| 亚洲精品国产无码| 国产精品igao视频| 性久久久久久久| 全亚洲最色的网站在线观看| 欧美特黄一区| 久久精品人人做| 可以在线看的av网站| 992tv免费直播在线观看| 日本91av在线播放| 成人免费淫片95视频观看网站| 中文字幕一区在线播放| 色先锋av男人资源先锋影院| 丁香婷婷久久久综合精品国产| 在线视频不卡国产| 亚洲一区色图| 一区二区三区在线高清| 亚洲人被黑人高潮完整版| 3344国产精品免费看| 亚洲精品一区二区三区福利| 亚洲美女区一区| 久久国产夜色精品鲁鲁99| 免费不卡av| 樱花草国产18久久久久| 久草手机在线视频| www.久久国产| 99久久999| 国产精品最新在线观看| 人人澡人人透人人爽| 人妻互换一区二区激情偷拍| 123区在线| 狠狠操视频网站| 一级在线免费视频| 亚州av电影免费在线观看| 亚洲大片在线观看| 日本高清视频在线观看| 日韩videos| 蝴蝶中文综合娱乐网| 欧美日韩午夜电影网| 午夜成在线www| 国产成人无码av在线播放dvd| 国产精品欧美大片| 国产在线视频网址| 伊人久久大香线蕉综合网站| 欧美日韩在线一| 狠狠躁夜夜躁久久躁别揉| 免费高清在线观看电视| 国产一区二区美女诱惑| 国产日韩欧美日韩大片| 无码免费一区二区三区| 国产精品美日韩| 日本中文字幕成人| 亚洲人成五月天| 日韩视频一区二区三区在线播放免费观看| 国产男人搡女人免费视频| 欧美日精品一区视频| 欧美激情黑人|