Model元数据定制与Model模板
元数据这一词对于计算机科学来说不算陌生,对元数据的解释最简单的解释就是描述数据的数据,那么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模板的更多相关文章
- .NET/ASP.NETMVC 深入剖析 Model元数据、HtmlHelper、自定义模板、模板的装饰者模式(三)
阅读目录: 7.HtmlHelper.HtmlHelper<T>中的ViewModel的类型推断 8.控制ViewModel中的某个属性的呈现(使用PartialView部分视图细粒度控制 ...
- MVC之Model元数据
Contronoller激活之后,ASP.NET MVC会根据当前请求上下文得到目标Action的名称,然后解析出对应的方法并执行之. 在整个Action方法的执行过程中,Model元数据的解析是一个 ...
- ASP.NET MVC Model元数据(五)
ASP.NET MVC Model元数据(五) 前言 在上一篇中我们描述了应用于Model上面的各种用于显示控制的特性类,在本篇中将详细的介绍这些特性类的应用,虽然它们跟Model元数据的直接关系并不 ...
- ASP.NET MVC Model元数据(四)
ASP.NET MVC Model元数据(四) 前言 前面的篇幅讲解了Model元数据生成的过程,并没有对Model元数据生成过程的内部和Model元数据结构的详细解释.看完本篇后将会对Model元数 ...
- ASP.NET MVC Model元数据(三)
ASP.NET MVC Model元数据(三) 前言 在上篇中我们大概的讲解了Model元数据的生成过程,并没有对Model元数据本身和详细的生成过程有所描述,本篇将会对详细的生成过程进行讲解,并且会 ...
- ASP.NET MVC Model元数据(二)
ASP.NET MVC Model元数据(二) 前言 在上篇中,给大家留个对Model元数据的印象,并没有对Model元数据有过多的讲解,而在本篇中也不会对Model元数据的本身来解释,而是针对于它的 ...
- ASP.NET MVC Model元数据(一)
ASP.NET MVC Model元数据(一) 前言 在我初学的时候对Model元数据的概念很模糊,或者说是在大脑中没有它的一个模型,作为小白的我去看网上的一些文章还是两眼一黑啥都看不明白,然后我想退 ...
- Model元数据提供机制小结
在最开始先我得说说我看这部分的情况,最开始被各种ModelMetadata和各种ModelMetadataProvider给搞晕了,就几页书花了我好大的精力去看,直到后来看了一幅类图,细细看各个类之间 ...
- ASP.NET MVC Model元数据
ASP.NET MVC Model元数据(三) 前言 在上篇中我们大概的讲解了Model元数据的生成过程,并没有对Model元数据本身和详细的生成过程有所描述,本篇将会对详细的生成过程进行讲解,并且会 ...
随机推荐
- (转载)编写高效的jQuery代码
原文地址:http://www.cnblogs.com/ppforever/p/4084232.html 最近写了很多的js,虽然效果都实现了,但是总感觉自己写的js在性能上还能有很大的提升.本文我计 ...
- CSS3动画:YouTube的红色激光进度条
本文只是讨论和实现了动画效果,并未将动画与页面实际下载关联,有朋友们问如何应用,可以使用现成的一些插件比如这个,这个,还有这个. 之前一篇文章<CSS3 动画一瞥>简单介绍了CSS3动画相 ...
- php操作xml
最近计划写个人的小网站,一系列原因选择了用php来写,最大的问题就是虽然php很流行,但我从来没有接触过php,看了一个多星期的基本语法后做些小练习热热身,但是期间是各种问题啊,主要是对php不熟悉, ...
- 基于Task的异步模式的定义
返回该系列目录<基于Task的异步模式--全面介绍> 命名,参数和返回类型 在TAP(Task-based Asynchronous Pattern)中的异步操作的启动和完成是通过一个单独 ...
- 如何获得PRINCE2认证
PRINCE2认证考试共有两种:基础级和从业级 一. 基础级考试 基础级考试是一种低水平的认证.如果想要进行从业级考试,必须要参加并通过该考试,或者已经获得pmp资质.基础级考试包括以下关键点: 1. ...
- EF架构~XMLRepository仓储的实现
回到目录 对于数据仓储大家应该都很熟悉了,它一般由几个仓储规范和实现它的具体类组成,而仓储的接口与架构本身无关,对于仓储的实现,你可以选择linq2Sql,EF,Nosql,及XML 等等,之前我介绍 ...
- GitHub & Bitbucket & GitLab & Coding 的对比分析
目前基于 Git 做版本控制的代码托管平台有很多种,比较流行的服务有 Github.Bitbucket. GitLab. Coding,他们各自有什么特点,个人使用者和开发团队又该如何选择? 在这篇文 ...
- Servlet开发技术,创建,以及Servlet的配置,web.xml的配置
直接上图,不废话!!! 第一:首先在Eclipse的包资源管理器中,单机鼠标右键,在弹出的快捷键菜单中选择“新建”/Servlet命令,在弹出的对话框中输入新建的Servlet所在的包和类名,然后单击 ...
- 在 xampp 环境下安装 laravel
网上搜了很多教程,很多都是采用命令行安装的.但是对于web前端来说,根本就不知道在干吗! 于是,打算写一篇文章,来教后面的人如何在 XAMPP 环境下安装 laravel. 初步认识 XAMPP(Ap ...
- require.js笔记
笔记参考来源:阮一峰 http://www.ruanyifeng.com/blog/2012/10/javascript_module.html 1. 浏览器端的模块只能采用“异步加载”方式 = ...