元数据这一词对于计算机科学来说不算陌生,对元数据的解释最简单的解释就是描述数据的数据,那么Model元数据当然是描述Model中各种成员的数据了,在ASP.NET MVC中ModelMetadata这个类专门用于描述Model及其成员的信息,这样就表明Model的描述需要一个ModelMetadata,Model里面的各个属性也需要ModelMetadata;换言之,ModelMetadata这个类有个自引用的现象,类的内部有个集合存储ModelMetadata。其声明如下

IEnumerable<ModelMetadata> Properties

这是ModelMetadata的一个成员,它的成员有很多,按现在的认识就分了两类,一种是包含上述属性的用于描述数据基本信息用的属性;一种是用于定制的属性,那部分包含定制信息的属性主要是用于呈现在View中或控制属性显示的模板。

  那么用于描述数据基本信息用的属性就有

类型

属性名

描述

Iemumerable<ModelMetadata>

Properties

属性成员的元数据集合

Type

ModelType

本身的类型

bool

IsComplexType

是否复杂类型

bool

IsNullableValueType

是否可空值

Type

ContainerType

父级类型

object

Model

本类的实例

string

PropertyName

在父类型中的属性名称

Dictionary<string,object>

AdditionalValue

存储自定义属性的字典集

ModelMetadataProvider

Provider

元数据的提供者

  在这个表中复杂类型这个词要稍作解释,其实也不算难,就是一个类型的值能通过字符串转换过来的就算是简单类型,反之则是复杂类型,例如整形(”1”),浮点型(”1.23”),日期(”2014-07-29”)等类型能通过字符串转换得到相应的(int,float,DateTime)类型的值,那么这个类型就算是简单类型,否则是复杂类型。

  另一部分用作定制的属性如下所示

类型 属性名 定制的Attribute 描述 备注
string TemplateHint HiddenInputAttribute UIHintAttribute 指定动态数据用来显示数据字段的模板或用户控件。 两个Attribute同时使用,后者具有更高的优先级
bool HideSurrounding   该特性用于指示是否应将属性值或字段值呈现为隐藏的 input 元素  
bool ShowForDisplay ScaffoldColumnAttribute   控制目标元素是否应该存在于基架之中  
bool ShowForEdit    
string DataTypeName DataTypeAttribute   指定要与数据字段关联的附加类型的名称。  
bool ConvertEmptyStringToNull DisplayFormatAttribute   指定 ASP.NET 动态数据如何显示数据字段以及如何设置数据字段的格式。  
string NullDisplayText    
string DisplayFormatString    
string EditFormatString    
bool IsReadOnly EditableAttribute ReadOnlyAttribute EditableAttribute:指示数据字段是否可编辑;
ReadOnlyAttribute:指定该特性所绑定到的属性是只读属性还是读/写属性。
两个Attribute同时使用,前者具有更高的优先级
string DisplayName DisplayAttribute DisplayNameAttribute 用于设置目标元素的显示名称 两者共同使用时,前者具有更高优先级
string ShowDisplayName   可以为实体分部类的类型和成员指定可本地化的字符串  
string Description    
int Order    
string watermark    
bool IsRequired RequiredAttribute   目标元素设置为是否必需的数据成员  

  Model模板则是利用Model元数据的定制信息来给HtmlHelper<TModel>的模板方法以特定的形式把数据以及元数据生成Html展示出来。那么这里的模板有框架里面预定义的模板,也可以由开发人员自己去定义的模板。下面则介绍预定义的模板。

  预定义模板主要使用的是UIHintAttribute来设置,如前面介绍元数据定制中所描述的:用于指定动态数据用来显示数据字段的模板或用户控件。下面还是以表格的形式展现各个预定义模板的使用还有结果。

模板名称 使用形式 结果
EmailAddress [UIHint("EmailAddress")]或者
[DataType(DataType.EmailAddress)]
DisplayFor:<a
href="mailto:foo@gmail.com">goo@gmail.com</a>
HiddenInput [UIHint("HiddenInput")] DisplayFor:1234567
    EditFor:<input id="Foo" name="Foo"
type="hidden" value="1234567"/>
Html [UIHint("Html")]或者
[DataType(DataType.Html)]
DisplayFor:<a href="www.google.com">google.com</a>
Text [UIHint("Text")]或者
[DataType(DataType.Text)]
DisplayFor:Admin
String [UIHint("String")] EditFor:<input class="text-box single-line"
id="Foo" name="Foo" type="text"
value="Admin"/>
Url [UIHint("Url")]或者
[DataType(DataType.Url)]
DisplayFor:<a
href="http://www.google.com">http://www.google.com</a>
MultilineText [UIHint("MultilineText")]或者
[DataType(DataType.MultilineText)]
EditFor:<textarea class="text-box multi-line"
id="Foo" name="Foo">Admin</textarea>
Password [UIHint("Password")]或者
[DataType(DataType.Password)]
EditFor:<input class="text-box single-line password"
id="Foo" name="Foo" type="password"
value=""/>
Decimal [UIHint("Decimal")] Display:123.00
    EditFor:<input class="text-box single-line" id="Foo" name="Foo"
type="text" value="123.00\"/>
Boolean [UIHint("Boolean")] Dislplay:<input id="Foo"
name="Foo" type="checkbox" value="true"
disable="true"/>
    EditFor:<input
id="Foo" name="Foo" type="checkbox"
value="true" disable="true"/>
<input name="Foo" type="hidden"
value="false"/>
Collection [UIHint("Collection")] Display:各元素的Display形式
    EditFor:各元素的Edit形式
Object [DisplayName("城市")] DisplayForModel:<div
class="display-label">城市</div>
<div class="display-field">佛山市</div>

  此时在一个以UserInfo类型为强类型的视图中调用@Html.DisplayForModel(),类的信息则会显示出来。但是若是UserInfo中的属性一定要是简单类型的;

  如果要给类中的某个成员定制模板,如给DateTime类型再定义一个MyDateTime模板

@model DateTime
时间是 @Model.ToString("yyyy-MM-dd HH:mm:ss")

然后给相应的成员使用上标记

[DataType(“MyDateTime”)]

则可。

  目前这部分内容还没学习完,经过后续的学习后会继续补充此文,由于还在学习,故会有理解得不恰当的地方,以上有什么说的不对的请指正,有什么好的建议或意见也请分享,谢谢!

Model元数据定制与Model模板的更多相关文章

  1. .NET/ASP.NETMVC 深入剖析 Model元数据、HtmlHelper、自定义模板、模板的装饰者模式(三)

    阅读目录: 7.HtmlHelper.HtmlHelper<T>中的ViewModel的类型推断 8.控制ViewModel中的某个属性的呈现(使用PartialView部分视图细粒度控制 ...

  2. MVC之Model元数据

    Contronoller激活之后,ASP.NET MVC会根据当前请求上下文得到目标Action的名称,然后解析出对应的方法并执行之. 在整个Action方法的执行过程中,Model元数据的解析是一个 ...

  3. ASP.NET MVC Model元数据(五)

    ASP.NET MVC Model元数据(五) 前言 在上一篇中我们描述了应用于Model上面的各种用于显示控制的特性类,在本篇中将详细的介绍这些特性类的应用,虽然它们跟Model元数据的直接关系并不 ...

  4. ASP.NET MVC Model元数据(四)

    ASP.NET MVC Model元数据(四) 前言 前面的篇幅讲解了Model元数据生成的过程,并没有对Model元数据生成过程的内部和Model元数据结构的详细解释.看完本篇后将会对Model元数 ...

  5. ASP.NET MVC Model元数据(三)

    ASP.NET MVC Model元数据(三) 前言 在上篇中我们大概的讲解了Model元数据的生成过程,并没有对Model元数据本身和详细的生成过程有所描述,本篇将会对详细的生成过程进行讲解,并且会 ...

  6. ASP.NET MVC Model元数据(二)

    ASP.NET MVC Model元数据(二) 前言 在上篇中,给大家留个对Model元数据的印象,并没有对Model元数据有过多的讲解,而在本篇中也不会对Model元数据的本身来解释,而是针对于它的 ...

  7. ASP.NET MVC Model元数据(一)

    ASP.NET MVC Model元数据(一) 前言 在我初学的时候对Model元数据的概念很模糊,或者说是在大脑中没有它的一个模型,作为小白的我去看网上的一些文章还是两眼一黑啥都看不明白,然后我想退 ...

  8. Model元数据提供机制小结

    在最开始先我得说说我看这部分的情况,最开始被各种ModelMetadata和各种ModelMetadataProvider给搞晕了,就几页书花了我好大的精力去看,直到后来看了一幅类图,细细看各个类之间 ...

  9. ASP.NET MVC Model元数据

    ASP.NET MVC Model元数据(三) 前言 在上篇中我们大概的讲解了Model元数据的生成过程,并没有对Model元数据本身和详细的生成过程有所描述,本篇将会对详细的生成过程进行讲解,并且会 ...

随机推荐

  1. HTML目录生成工具

    目录 内容简介 工具代码 使用方法 工具改进 内容简介 园子里面很多博主都会为自己的博文创建目录,方便大家浏览.我很好奇大家是怎么做的,是不是有自动生成目录的工具可以推荐一下(我知道word可以,但是 ...

  2. Kinect for Windows SDK 1.8的改进及新特性

    今年3月, 微软推出了Kinect for Windows SDK 1.7 更新,包括了手势识别 Kinect Interactions 和实时 3D 建模 Kinect Fusion 两项新技术. ...

  3. 使用抓包工具SpyNet对你的网络进行监控

    步骤1:下载并安装SpyNet Sniffer嗅探器之后,第一次运行SpyNet Sniffer后,将会弹出[Settings(设置)]对话框,在其中选择需要监听对象,如图所示. 步骤2:单击[Act ...

  4. Linux vim命令

    介绍 vim命令和vi的操作基本一致,vim命令的参数很多,我在这里列出了一些平时需要用的一些参数,vim主要有两个界面一个是esc的操作界面还有一个是输入i的编辑界面. 移动光标 0 (零):将光标 ...

  5. .NET在线培训 | C#在线培训 | .NET培训 | 最课程培训

    最课程(www.zuikc.com) 软件开发培训,在线软件培训的创新者!我们的创新在于: 1:一次购买,终身服务.每个最课程学员都会分配一位专职教师及一位监管教师,点对点跟进课程进度,直到您学会课程 ...

  6. 每天一个linux命令(19):find 命令概览

    Linux下find命令在目录结构中搜索文件,并执行指定的操作.Linux下find命令提供了相当多的查找条件,功能很强大.由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时 ...

  7. 总结baiduTemplate和djangoTemplate的学习

    引入      开发工作中需要,除了今天要介绍的两种template,还有很多模板,但他们的终点都是相同的,都是为了开发的便利.       模板的作用       是一套模板语法,开发者可以通过写一 ...

  8. linux安装locust

    linux安装locust 1. 安装epel扩展源(目的是为了在安装Pip时不出现一堆乱七八糟的错误信息) EPEL(http://fedoraproject.org/wiki/EPEL) 是由 F ...

  9. 怎样将多个CSS文件导入一个CSS文件中

    问题: 在HTML中引入css的其中的两个方法:    导入式和链接式的目的都是将一个独立的css文件引入一个文件中,二者的区别不大,事实上,二者最大的区别在于链接式使用html的标记引入外部css文 ...

  10. Ext.grid.CheckboxSelectionModel状态设置

    直接上代码: var model = grid.getSelectionModel(); model.selectAll();//选择所有行 model.selectFirstRow();//选择第一 ...