基于easyui的webform扩展(续)
基于easyui的webform扩展(续)
回顾
《前端基于easyui的mvc扩展》、《前端基于easyui的mvc扩展(续)》、《基于easyui的webform扩展》这几篇讲解了如何在mvc以及web form内来实现前端使用easyui以及在后端使用基于ValidationAttribute进行验证(mvc本身就有支持),但是这都是以Framework4.0为基础的,那么当我们遇到3.5或者是更早以前的版本的时候,现在这套应用就需要重新重构了。
首先来梳理一下整个流程,大致的流程如下:
- 通过调用需要展示的控件方法
- 解析属性上的验证元数据
- 生成符合easyui验证规则的html
- 提交表单到后端
- 对表单转化后的对象进行验证
- 如果通过验证则可以对对象进行操作,不通过则直接返回
mvc和web form在前端的方式基本上都是用一样的,那么也就是说要让我们编写的代码能支持更多的版本的情况下,假如我们自己实现一套验证特性的话,那么只要让前端生成的规则保持一致,后端的话,只有web form是自己去验证这一步的。
实现
那么参考前几篇的结果以及ValidationAttribute,我们很快便能整理出一套跟ValidationAttribute相似的验证特性了,部分代码如下:
//验证基类[AttributeUsage(AttributeTargets.Property,AllowMultiple=true,Inherited=false)]publicabstractclassCustomValidationBaseAttribute:Attribute{privateobject m_Model =null;protectedobjectModel{get{return m_Model;}}privatestring m_ErrorMessage =null;publicstringErrorMessage{get{return m_ErrorMessage;}set{ m_ErrorMessage = value;}}publicboolIsValid(object model,object value){if(model ==null)returnfalse;
m_Model = model;returnIsValid(value);}publicvirtualstringFormatErrorMessage(string displayName){returnstring.Format(ErrorMessage, displayName);}protectedabstractboolIsValid(object value);}//必填特性[AttributeUsage(AttributeTargets.Property,AllowMultiple=false,Inherited=false)]publicclassCustomRequiredAttribute:CustomValidationBaseAttribute{protectedoverrideboolIsValid(object value){return value !=null&&!string.IsNullOrEmpty(value.ToString());}}
有了特性,那么接下来只要根据不同的环境,来生成相同的easyui验证规则就可以了。
首先分析一下各种控件的规则,主要有以下3种情况:
- linkbutton这种不需要进行数据绑定,只要显示文本或某些属性的
- validatebox、numberbox、combobox等是需要解析表达式,在model存在的情况下,要显示出值的
- Label只要显示属性上配置的DisplayName的,虽然不是easyui的控件,但是2里面的控件共用表达式树的解析
其实以上2-3的区别仅仅是在控件上添加一个属于easyui的样式表而已,于是使用如下2中类来区分以上3种情况,代码如下:
internalclassBuilderBase{publicBuilderBase(string tag,string attributeJson):this(tag,null, attributeJson){}publicBuilderBase(string tag,string control,string attributeJson){//省略,文章最后提供详细源码}//扩展Builder,比如Linkbutton要添加文本或其他编辑控件要增加name及验证规则protectedvirtualvoidExpandFor(TagBuilder builder){}}internalclassParseExpressionBuilder:BuilderBase{publicParseExpressionBuilder(string tag,Expression<Func<TModel,object>> expression,string attributeJson):this(tag,null, expression,default(TModel), attributeJson){}publicParseExpressionBuilder(string tag,string control,Expression<Func<TModel,object>> expression,TModel model,string attributeJson):base(tag, control, attributeJson){//略}protectedoverridevoidExpandFor(TagBuilder builder){//略}//此方法用来处理不同控件的绑定值操作protectedvirtualvoidAppendValue(refTagBuilder builder,object value){if(value !=null)
builder.AddAttribute("value", value.ToString());}}
这里将具体的生成规则都放在了一些列的Builder内,但是为了保证在mvc和web form内能生成相同easyui的easyui规则,由于我们自定义的规则是参考ValidationAttribute的,因此我们只要根据接口来实现我们自定义的那一部分就可以了,其实只要适当的修改第一篇文章内的生成规则便可以完工了,部分代码如下:
//这里挑选了必填验证的代码,跟之前的相比仅仅是验证特性的对象不同而已var attribute = validationAttrs.FirstOrDefault(attr => attr isCustomRequiredAttribute);if(attribute !=null){
tag.AddAttribute("required","true");
tag.AddAttribute("missingMessage", attribute.ErrorMessage);}
而上篇提到的EasyUIHelper仅仅是提供给外部生成的公用方法而已,它的代码大致如下:
publicclassEasyUIHelper{publicstaticstringLabel(Expression<Func<TModel,object>> expression,string attributeJson){returnnewLabelBuilder(expression, attributeJson);}publicstaticstringValidateText(Expression<Func<TModel,object>> expression,TModel model,string attributeJson){returnnewValidateboxBuilder(expression, model,"text", attributeJson);}//针对3.5的其他重构和其他方法省略,具体请看源码}
完成了前端的生成规则以后,接下来就是对于后端验证进行重构了,代码与之前的差别不大,仅仅是把原本基于ValidationAttribute改为基于CustomValidationBaseAttribute来完成,为了节省篇幅代码就不写了,具体的可以查看源码。
结尾
由于本篇是基于前几篇的一个总结和对之前版本的兼容,因此内容相对比较少,如果对这几篇的内容有什么问题请指出,谢谢大家,另外源码在此(从代码库中抽出来的一部分)。
基于easyui的webform扩展(续)的更多相关文章
- 基于easyui的webform扩展
基于easyui的webform扩展 回顾 <前端基于easyui的mvc扩展>.<前端基于easyui的mvc扩展(续)>前两篇介绍了mvc内如何基于easyui进行扩展,在 ...
- 前端基于easyui的mvc扩展(续)
前端基于easyui的mvc扩展(续) 回顾及遗留问题 上一篇讲解了基于easyui的mvc扩展的基本实现,已经降低了在mvc内使用easyui的难度,但是仍然还有一些问题: 当我们要给生成的控件设置 ...
- 基于easyui的验证扩展
基于easyui的验证扩展 ##前言 自己做项目也有好几年的时间了,一直没有时间整理自己的代码,趁春节比较闲,把自己以前的代码整理了一篇.这是基于easyui1.2.6的一些验证扩展,2012年就开始 ...
- 前端基于easyui的mvc扩展
背景 由于MVC的前端是基于jquery.validate和jquery.validate.unobtrusive来实现的,但是当我们要使用其他的ui组件且组件本身就带有完整的验证功能的话,那么要让它 ...
- 基于EasyUI Treegrid的权限管理资源列表
1. 前言 最近在开发系统权限管理相关的功能,主要包含用户管理,资源管理,角色管理,组类别管理等小的模块.之前的Web开发中也用过jQueryEasyUI插件,感觉这款插件简单易用,上手很快.以前用到 ...
- ABP 初探 之基于EasyUI的CURD
结束了天天加班的项目,项目虽然结束,但还是有点小问题,只能在后期优化当中完成了,本次做项目采用了,MVC.Webapi.Entityframework,在园了里看到了有关ABP的介绍,同样ABP也是最 ...
- 基于Spring的可扩展Schema进行开发自定义配置标签支持
一.背景 最近和朋友一起想开发一个类似alibaba dubbo的功能的工具,其中就用到了基于Spring的可扩展Schema进行开发自定义配置标签支持,通过上网查资料自己写了一个demo.今天在这里 ...
- 基于EasyUI实现windows桌面
之前为大家介绍了 基于jquery tool实现的windows桌面效果,今天给大家带来一款基于EasyUI实现windows桌面.这款桌面适用浏览器:360.FireFox.Chrome.Safar ...
- 基于 HtmlHelper 的自定义扩展Container
基于 HtmlHelper 的自定义扩展Container Intro 基于 asp.net mvc 的权限控制系统的一部分,适用于对UI层数据呈现的控制,基于 HtmlHelper 的扩展组件 Co ...
随机推荐
- POJ1719- Shooting Contest(二分图最大匹配)
题目链接 题意:给定一个矩阵,每列有两个白点,其它都是黑点,如今要求每列选一个白点,使得每一行至少包括一个白点被选中 思路:利用白点所在的位置用行指向列建图,用行去匹配列,最大匹配数假设不等于行数的话 ...
- SQL Server 板机
触发器是一种特殊类型的存储过程.们介绍的存储过程. 触发器主要是通过事件进行触发被自己主动调用运行的. 而存储过程能够通过存储过程的名称被调用. Ø 什么是触发器 触发器对表进行插入.更新.删除的时候 ...
- The Swift Programming Language-官方教程精译Swift(9) 枚举-- --Enumerations
枚举定义了一个通用类型的一组相关的值,使你可以在你的代码中以一个安全的方式来使用这些值. 如果你熟悉 C 语言,你就会知道,在 C 语言中枚举指定相关名称为一组整型值.Swift 中的枚举更加灵活 ...
- iOS开发之在地图上绘制出你运行的轨迹
首先我们看下如何在地图上绘制曲线.在Map Kit中提供了一个叫MKPolyline的类,我们可以利用它来绘制曲线,先看个简单的例子. 使用下面代码从一个文件中读取出经纬度,然后创建一个路径:MKPo ...
- orleans开篇之hello world
orleans开篇之hello world 什么是orleans Orleans是一个建立在.NET之上的,设计的目标是为了方便程序员开发需要大规模扩展的云服务.Orleans项目基本上被认为是并行计 ...
- C语言 链表
原文:C语言 链表 最近在复习数据结构,想把数据结构里面涉及的都自己实现一下,完全是用C语言实现的. 自己编写的不是很好,大家可以参考,有错误希望帮忙指正,现在正处于编写阶段,一共将要实现19个功能. ...
- 在地图中使用Java
Map以按键/数值对的形式存储数据,和数组很类似,在数组中存在的索引,它们本身也是对象. Map的接口 Map---实现Map Map.Entry--Map的内部类 ...
- WimMaker 2.0 (2013.10) WIM制作工具
WimMaker 2.0 (2013.10) WIM制作工具 可用于制作PE启动内核的Wim文件 说明: 因本软件使用.NET2.0制作,故主要用于制作WIM映像不用于备份还原系统(虽可用,但不专业, ...
- Java 多线程之happens-before规则解释
关于happens-before规则的解释网上有很多,我就不敢班门弄斧了.贴出两篇不错的文章以供学习. 1.happens-before俗解 2.深入Java内存模型--happen-before规则
- Gimp教程:简约手机图标风格
效果: 在一个国外博客上翻到的图标制作教程,效果类似于Cowon J3的默认图标风格. 制作过程很简单,只需两三步,不多说了,上步骤 Step1.新建50×50的黑色背景 Step2.新建 ...