在上一篇中我們描述了應(yīng)用于Model上面的各種用于顯示控制的特性類,在本篇中將詳細(xì)的介紹這些特性類的應(yīng)用,雖然它們跟Model元數(shù)據(jù)的直接關(guān)系并不大,但是我們可以用它們?cè)诰幋a階段控制運(yùn)行時(shí)的顯示。
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、重慶小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了鶴山免費(fèi)建站歡迎大家使用!
什么是Model元數(shù)據(jù)?
生成Model元數(shù)據(jù)的過程【一】
生成Model元數(shù)據(jù)的過程【二】
ModelMetaData的定義、詳解
Model元數(shù)據(jù)應(yīng)用(常用特性應(yīng)用)-1
Model元數(shù)據(jù)應(yīng)用(自定義視圖模板)-2
Model元數(shù)據(jù)應(yīng)用(IMetadataAware接口使用)-3
所用示例:
代碼1-1
public class Customer { public string CustomerID { get; set; } public string Name { get; set; } public DateTime RegistrationDate{ get; set; } public Address Address { get; set; } } public class Address { public string AddressName { get; set; } }
這是下面所要用的示例Model,下面的代碼1-2示例是使用自定義模型綁定器用于獲取Model數(shù)據(jù)的,大家只需要看數(shù)據(jù)的值就行了,對(duì)于Model綁定部分后續(xù)的篇幅的中再介紹。
代碼1-2
public object BindModel(ControllerContext controllerContext, ModelBindingContext bindingContext) { return new Customer() { CustomerID = "010", Name = "測(cè)試人員", RegistrationDate = DateTime.Now, Address = new Address() { AddressName = "天空之城" } }; }
HiddenInputAttribute類型所表示的意思是將應(yīng)用的屬性顯示為隱藏輸入域類型(Hidden),其中包含一個(gè)屬性DisplayValue表示是否顯示這個(gè)隱藏的輸入域,我們修改一下代碼1-1中的內(nèi)容:
代碼1-3
[HiddenInput(DisplayValue=true)] public string CustomerID { get; set; }
然后看一下我們?cè)谝晥D界面的代碼:
代碼1-4
@model ConsoleApplication2.Customer @{ ViewBag.Title = "Show"; }Show
@Html.EditorForModel()
結(jié)果如圖1.
圖1
在圖1中我們看到CustomerID對(duì)應(yīng)的屬性值“010”在頁面里顯示為只讀的文本狀態(tài),生成的Html代碼如下:
修改代碼1-3中的DisplayValue屬性值為true后,視圖部分的代碼不變,運(yùn)行結(jié)果如圖2。
圖2
在圖2中,已經(jīng)看不到CustomerID屬性所表示的項(xiàng)了,看到這里相信我們已經(jīng)了解了HiddenInputAttribute類型的使用了吧。
看上面的圖2 ,RegistrationDate屬性所對(duì)應(yīng)的值都是日期時(shí)間格式的,那怎么控制屬性值的輸入樣式呢?比如說想讓屬性值顯示為日期類型,來看代碼1-5
代碼1-5
[DataType(DataType.Date)] public DateTime RegistrationDate{ get; set; }
視圖部分的代碼不用改變來看一下結(jié)果圖3
圖3
從上圖中看出輸出值的格式樣式已經(jīng)改變了。
DisplayAttribute類型用于指示的屬性所顯示的標(biāo)簽值的修改,比如說圖3中的Name和RegistrationDate,想顯示我們成我們自定義的名稱就要用DisplayAttribute類型,來看代碼1-6.
代碼1-6
[Display(Name="姓名")] public string Name { get; set; } [DataType(DataType.Date)] [Display(Name="注冊(cè)日期")] public DateTime RegistrationDate{ get; set; }
視圖部分的代碼依舊不變,我們來看一下運(yùn)行的結(jié)果圖4。
圖4
從圖4我們已經(jīng)看到更改了
本小節(jié)對(duì)視圖模板和UIHintAttribute類型的使用做一些簡(jiǎn)單的介紹。
視圖模板是什么意思呢?就是根據(jù)Model元數(shù)據(jù)提供的信息生成為指定的視圖模板所對(duì)應(yīng)的Html代碼(包含Html元素樣式),我們看一下示例,這樣比較直觀。
代碼2-1
public class Customer { [HiddenInput(DisplayValue=false)] public string CustomerID { get; set; } [Display(Name="姓名")] [UIHint("Password")] public string Name { get; set; } [DataType(DataType.Date)] [Display(Name="注冊(cè)日期")] public DateTime RegistrationDate{ get; set; } public Address Address { get; set; } }
從代碼2-1中的Name屬性上看到UIHintAttribute類型的特性,使用它的意思就是指定一個(gè)視圖模板來為這個(gè)屬性生成Html代碼,這樣為了直觀的可以看出來所以使用了Password視圖模板,這個(gè)Password視圖模板的意思講Model元數(shù)據(jù)所對(duì)應(yīng)的屬性值生成為一個(gè)單行的文本框Input元素,并且元素中的字符是不可見的,是可編輯的??匆幌陆Y(jié)果圖5.
圖5
所對(duì)應(yīng)的Html代碼2-2
代碼2-2
系統(tǒng)為我們提供了許多視圖模板,但是也不能亂用的,要保持使用的視圖模板所需類型和指定的屬性一致的。
細(xì)心的朋友可能會(huì)發(fā)現(xiàn)在上面的顯示頁面中都沒有發(fā)現(xiàn)Address屬性的值,這個(gè)在前篇就強(qiáng)調(diào)過,因?yàn)锳ddress屬性對(duì)應(yīng)的類型在生成Model元數(shù)據(jù)的時(shí)候被判別為復(fù)雜類型,而模板視圖輔助器是不會(huì)去對(duì)復(fù)雜類型進(jìn)行處理的,那我們要怎么顯示Address屬性中的值呢?
我們使用自定義的視圖模板,當(dāng)然作用不止這么一點(diǎn),只是用來講解而已。
首先項(xiàng)目中的/Views/Shared的目錄下新建一個(gè)名為EditorTemplates的文件夾,然后在此文件夾中新建一個(gè)強(qiáng)類型的分布視圖文件,類型是指定屬性對(duì)應(yīng)的類型,并且命名視圖文件為指定屬性的類型名稱,按照示例來說就是Address類型的名稱就是Address,完成后應(yīng)該是這樣的,圖6
圖6
在此視圖中添加如代碼2-3。
代碼2-3
@Html.LabelFor(m=>m.AddressName) @Html.EditorFor(m => m.AddressName)
然后修改代碼2-1中的Address屬性,并且修改Address類型里的AddressName屬性要顯示的名稱,用我們上面講過的DisplayAttribute類型示例代碼2-4
代碼2-4
public class Customer { [HiddenInput(DisplayValue=false)] public string CustomerID { get; set; } [Display(Name="姓名")] [UIHint("Password")] public string Name { get; set; } [DataType(DataType.Date)] [Display(Name="注冊(cè)日期")] public DateTime RegistrationDate{ get; set; } [UIHint("Address")] public Address Address { get; set; } } public class Address { [Display(Name="地址名稱")] public string AddressName { get; set; } }
然后再修改掉我們主視圖頁面的代碼,使用EditFor輔助器單獨(dú)的對(duì)Address屬性進(jìn)行處理操作,如代碼2-5所示。
代碼2-5
@model ConsoleApplication2.Customer @{ ViewBag.Title = "Show"; }Show
@Html.EditorForModel()
@Html.EditorFor(m=>Model.Address)
然后我們看一下修改后的結(jié)果圖7.
圖7
還有一些其他的特性類型的使用示例會(huì)在以后修改本篇,現(xiàn)在本人也不是太熟不能亂寫的。
前面的篇幅對(duì)Model元數(shù)據(jù)的生成的詳細(xì)過程以及使用都有所粗略的講解,想必這時(shí)大家已經(jīng)對(duì)Model元數(shù)據(jù)有所了解了,這個(gè)小節(jié)介紹如何使用IMetadataAware接口類型來實(shí)現(xiàn)我們直接操作Model元數(shù)據(jù),從而跳過那些使用系統(tǒng)自帶的那些特性類,它們是可以先設(shè)置,但是我們也可以自定義的設(shè)置Model元數(shù)據(jù)的值,好了廢話不多說了往下看吧。
在Model元數(shù)據(jù)(二)的篇幅里,我們提到過的內(nèi)容中,在Model元數(shù)據(jù)生成后的最后一步過程是會(huì)調(diào)用Model元數(shù)據(jù)生成提供程序中的一個(gè)函數(shù),在此函數(shù)中MVC框架會(huì)檢索當(dāng)前Model元數(shù)據(jù)所指定的類型上的所有特性類型集合,檢索出實(shí)現(xiàn)了IMetadataAware接口的特性類,然后使用這個(gè)實(shí)現(xiàn)類型對(duì)當(dāng)前Model元數(shù)據(jù)進(jìn)行操作。可能朋友們看我的這段敘述有點(diǎn)模糊,那我們直接來看示例代碼吧。
首先我們定義個(gè)類型來實(shí)現(xiàn)IMetadataAware接口類型,而根據(jù)MVC框架檢索的前提約定,我們需要把自定義的類型定義為特性類,如代碼3-1所示:
代碼3-1
[AttributeUsage(AttributeTargets.Class|AttributeTargets.Property,AllowMultiple=false,Inherited=false)] public class MyCustomMetadataAware:Attribute,IMetadataAware { public void OnMetadataCreated(ModelMetadata metadata) { if (metadata != null) { if (metadata.DisplayName == "地址名稱") { metadata.DisplayName = "經(jīng)過IMetadataAware修改的地址名稱"; } } } }
在代碼3-1中,我們自定義的類型MyCustomMetadataAware實(shí)現(xiàn)了IMetadataAware接口類型,并且在OnMetadataCreated()方法中對(duì)metadata參數(shù)(Model元數(shù)據(jù))進(jìn)行修改,修改的屬性DisplayName是Model元數(shù)據(jù)控制器對(duì)應(yīng)屬性顯示的名稱,在這個(gè)MyCustomMetadataAware類型中我們把這個(gè)DisplayName屬性值如果符合某種條件下修改掉(為了配合上面的示例)。
我們?cè)賮砜匆幌挛覀兊腗odel定義,如代碼3-2:
代碼3-2
public class Customer { [HiddenInput(DisplayValue=false)] public string CustomerID { get; set; } [Display(Name="姓名")] [UIHint("Password")] public string Name { get; set; } [DataType(DataType.Date)] [Display(Name="注冊(cè)日期")] public DateTime RegistrationDate{ get; set; } [UIHint("Address")] public Address Address { get; set; } } public class Address { [Display(Name="地址名稱")] [MyCustomMetadataAware] public string AddressName { get; set; } }
在代碼3-2中,我們把Model中的Address屬性所對(duì)應(yīng)的Address類型中的AddressName屬性加上了我們自定義的特性類,意在修改這個(gè)屬性最后在頁面上顯示出來的值。
我們看一下修改后的結(jié)果圖8.
圖8
從圖8中我們可以清楚的看到對(duì)應(yīng)地址欄的標(biāo)簽名稱已經(jīng)被修改掉了,對(duì)于系統(tǒng)提供的這個(gè)IMetadataAware接口我們可以做更多的自定義操作,這種方式的編程模式我們也是很常見的。
Model元數(shù)據(jù)部分到這里就全部結(jié)束了,其中也會(huì)有很多細(xì)節(jié)的部分沒有講的很到位、沒有很全面,因?yàn)椴┲魇切“子惺裁磳懙牟缓玫牡胤脚笥褌兛梢蕴岢鰜恚視?huì)學(xué)習(xí)并且再來回的修改篇幅,能在這里為大家盡一點(diǎn)薄力感到很榮幸,也謝謝大家的支持。下一個(gè)系列將是Model綁定的部分,大家敬請(qǐng)期待。