基于easyui的webform扩展(续)

回顾

  《前端基于easyui的mvc扩展》《前端基于easyui的mvc扩展(续)》《基于easyui的webform扩展》这几篇讲解了如何在mvc以及web form内来实现前端使用easyui以及在后端使用基于ValidationAttribute进行验证(mvc本身就有支持),但是这都是以Framework4.0为基础的,那么当我们遇到3.5或者是更早以前的版本的时候,现在这套应用就需要重新重构了。

  首先来梳理一下整个流程,大致的流程如下:

  1. 通过调用需要展示的控件方法
  2. 解析属性上的验证元数据
  3. 生成符合easyui验证规则的html
  4. 提交表单到后端
  5. 对表单转化后的对象进行验证
  6. 如果通过验证则可以对对象进行操作,不通过则直接返回

  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种情况:

  1. linkbutton这种不需要进行数据绑定,只要显示文本或某些属性的
  2. validatebox、numberbox、combobox等是需要解析表达式,在model存在的情况下,要显示出值的
  3. 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来完成,为了节省篇幅代码就不写了,具体的可以查看源码。

结尾

  由于本篇是基于前几篇的一个总结和对之前版本的兼容,因此内容相对比较少,如果对这几篇的内容有什么问题请指出,谢谢大家,另外源码在此(从代码库中抽出来的一部分)。

 
 
分类: C#想法

基于easyui的webform扩展(续)的更多相关文章

  1. 基于easyui的webform扩展

    基于easyui的webform扩展 回顾 <前端基于easyui的mvc扩展>.<前端基于easyui的mvc扩展(续)>前两篇介绍了mvc内如何基于easyui进行扩展,在 ...

  2. 前端基于easyui的mvc扩展(续)

    前端基于easyui的mvc扩展(续) 回顾及遗留问题 上一篇讲解了基于easyui的mvc扩展的基本实现,已经降低了在mvc内使用easyui的难度,但是仍然还有一些问题: 当我们要给生成的控件设置 ...

  3. 基于easyui的验证扩展

    基于easyui的验证扩展 ##前言 自己做项目也有好几年的时间了,一直没有时间整理自己的代码,趁春节比较闲,把自己以前的代码整理了一篇.这是基于easyui1.2.6的一些验证扩展,2012年就开始 ...

  4. 前端基于easyui的mvc扩展

    背景 由于MVC的前端是基于jquery.validate和jquery.validate.unobtrusive来实现的,但是当我们要使用其他的ui组件且组件本身就带有完整的验证功能的话,那么要让它 ...

  5. 基于EasyUI Treegrid的权限管理资源列表

    1. 前言 最近在开发系统权限管理相关的功能,主要包含用户管理,资源管理,角色管理,组类别管理等小的模块.之前的Web开发中也用过jQueryEasyUI插件,感觉这款插件简单易用,上手很快.以前用到 ...

  6. ABP 初探 之基于EasyUI的CURD

    结束了天天加班的项目,项目虽然结束,但还是有点小问题,只能在后期优化当中完成了,本次做项目采用了,MVC.Webapi.Entityframework,在园了里看到了有关ABP的介绍,同样ABP也是最 ...

  7. 基于Spring的可扩展Schema进行开发自定义配置标签支持

    一.背景 最近和朋友一起想开发一个类似alibaba dubbo的功能的工具,其中就用到了基于Spring的可扩展Schema进行开发自定义配置标签支持,通过上网查资料自己写了一个demo.今天在这里 ...

  8. 基于EasyUI实现windows桌面

    之前为大家介绍了 基于jquery tool实现的windows桌面效果,今天给大家带来一款基于EasyUI实现windows桌面.这款桌面适用浏览器:360.FireFox.Chrome.Safar ...

  9. 基于 HtmlHelper 的自定义扩展Container

    基于 HtmlHelper 的自定义扩展Container Intro 基于 asp.net mvc 的权限控制系统的一部分,适用于对UI层数据呈现的控制,基于 HtmlHelper 的扩展组件 Co ...

随机推荐

  1. Linux应用环境

    转载Linux应用环境 阅读目录 引言 使用 Linux 的一些困难和解决方法 我眼中的Linux哲学总纲 我这一系列随笔中展现出的Linux哲学 Linux之得和Linux之失 总结 回到顶部 引言 ...

  2. 【百度地图API】建立全国银行位置查询系统(一)——如何创建地图

    原文:[百度地图API]建立全国银行位置查询系统(一)--如何创建地图 <摘要>你将在第一章中学会以下知识: 如何创建一个网页文件 怎样利用百度地图API建立一张2D地图,以及3D地图 如 ...

  3. js 上一天、下一天

    function Previousday() { var curDate = new Date(CreateDate_Temp); * * * ); var strDate = preDate.get ...

  4. 专访雷水果国:离1.5K至18K 一个程序猿5每年的成长之路

    我只是一个小菜鸟,对于自主学习和交流PHP(jquery,linux,lamp,shell,javascript,server)等一系列的知识.小菜鸟创建了一个群.希望光临本博客的人能够进来交流. 寻 ...

  5. Linux进程和线程的比較

    进程与线程 參考:http://www.cnblogs.com/blueclue/archive/2010/07/16/1778855.html 首先比較Linux进程和线程的创建的差别,以此展开: ...

  6. 注意,WebDeploy服务会占用80端口。(Windows关闭了IIS,80端口任然被占用)

    最近遇到一个很奇怪的事情,Windows上的 IIS 网站 全关掉了,80端口仍然被占用.然后我新装了一台服务器,一个一个组件地装,装一个测一次,最后发现,WebDeploy这个组件,会占用80端口. ...

  7. shell awk统计重复个数

    awk是一个很强大的工具,一个常见的用法就是统计一个文件中重复的列值的个数,这也是面试时面试官经常问的一个问题. 举个例子: 有个文件file.log的内容如下: http://www.sohu.co ...

  8. [置顶] NB多项式事件模型、神经网络、SVM之函数/几何间隔——斯坦福ML公开课笔记6

    转载请注明:http://blog.csdn.net/xinzhangyanxiang/article/details/9722701 本篇笔记针对斯坦福ML公开课的第6个视频,主要内容包括朴素贝叶斯 ...

  9. 九度OJ 1035:找出直系亲属(二叉树)

    题目1035:找出直系亲属 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:1309 解决:521 题目描述: 如果A,B是C的父母亲,则A,B是C的parent,C是A,B的child,如 ...

  10. Windows 下安装 Oracle 12c 教程

    原文 Windows 下安装 Oracle 12c 教程 申明:本文原作者:Jmq   本文给大家带来的是 Oracle 12C 的安装教程. 1.准备 1.1 下载 Oracle 12c 安装程序 ...