JQuery EasyUI类库,大家不会陌生,出来已经有很多年了。个人感觉还是很好用的,作者更新频率也很快,bug也及时修复。

  最近在整理以前的代码,找到了这个组件,它是将EasyUI组件封装成MVC控件,这样我们就可以不用写那些html标签了,我们先看看调用方式

<form id="form1">
@Html.HiddenFor(c => c.ID)
@Html.HiddenFor(c => c.EditMode)
@Html.HiddenFor(c => c.CodeTypeID)
@Html.HiddenFor(c => c.CreateUserID)
<table border="1" style="width: 100%;">
<tr>
<td style="width: 100px;">@Html.EasyUI().LabelFor(c => c.CodeID).Required(true)</td>
<td>@Html.EasyUI().ValidateBoxFor(c => c.CodeID).Required(true).Width("60%")</td>
</tr>
<tr>
<td>@Html.EasyUI().LabelFor(c => c.CodeName).Required(true)</td>
<td>@Html.EasyUI().ValidateBoxFor(c => c.CodeName).Required(true).Width("60%")</td>
</tr>
<tr>
<td>@Html.EasyUI().LabelFor(c => c.CodeTypeName)</td>
<td>@Html.DisplayFor(c => c.CodeTypeName)</td>
</tr>
<tr>
<td>@Html.EasyUI().LabelFor(c => c.IsUsed)</td>
<td>@Html.DropDownListMetaCodeFor(c => c.IsUsed, MetaSourceType.Null, string.Empty, new{ @style = "width:60%;" })</td>
</tr>
<tr>
<td>@Html.EasyUI().LabelFor(c => c.SortOrder)</td>
<td>@Html.EasyUI().NumberBoxFor(c => c.SortOrder).Min(10).Value(10).Width("60%")</td>
</tr>
<tr>
<td>@Html.EasyUI().LabelFor(c => c.CreateUserName)</td>
<td>@Html.EasyUI().ValidateBoxFor(c => c.CreateUserName).Width("60%")</td>
</tr>
<tr>
<td>@Html.EasyUI().LabelFor(c => c.CreateTime)</td>
<td>@Html.EasyUI().DateBoxFor(c => c.CreateTime)</td>
</tr>
</table>
</form>

  

  我们再来看看代码是如何实现的,下面是整个项目布局

  其实代码不复杂,最关键的是TagElementBuilder.cs这个类

using System;
using System.Linq;
using System.Web;
using System.Web.Mvc; namespace NS.Utility.EasyUI
{
public abstract class TagElementBuilder<T> : IHtmlString where T : class
{
#region 私有变量
private TagBuilder tagBuilder;
#endregion #region 公有属性
/// <summary>
/// 组件Tag标签类型.包括input,select,label等
/// </summary>
public abstract string TagName { get; } /// <summary>
/// Tag标签组装类
/// </summary>
protected TagBuilder TagBuilder
{
get
{
if (this.tagBuilder != null)
return this.tagBuilder;
return this.tagBuilder = new TagBuilder(TagName);
}
}
#endregion #region 私有方法
/// <summary>
/// 判断class名称是否存在
/// </summary>
/// <param name="className"></param>
/// <returns></returns>
private bool ContainsClass(string className)
{
string classs;
if (!TagBuilder.Attributes.TryGetValue("class", out classs))
{
return false;
} var classArray = classs.Split(new[] { ' ' }, StringSplitOptions.RemoveEmptyEntries).ToArray();
return classArray.Any(i => string.Equals(i, className, StringComparison.OrdinalIgnoreCase));
}
#endregion #region 公有方法 /// <summary>
/// 设置ID属性值
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public T ID(string id)
{
this.TagBuilder.GenerateId(id);
return this as T;
} /// <summary>
/// 设置Name属性值
/// </summary>
/// <param name="name"></param>
/// <returns></returns>
public T Name(string name)
{
this.TagBuilder.MergeAttribute("name", name, true);
return this as T;
} /// <summary>
/// 设置Attribute属性列表
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <param name="replaceExisting"></param>
/// <returns></returns>
public T Attribute(string key, string value, bool replaceExisting = false)
{
this.TagBuilder.MergeAttribute(key, value, replaceExisting);
return this as T;
} /// <summary>
/// 增加class属性值
/// </summary>
/// <param name="className"></param>
/// <returns></returns>
public T AddClass(string className)
{
if (string.IsNullOrWhiteSpace(className))
{
return this as T;
} if (ContainsClass(className))
{
return this as T;
} TagBuilder.AddCssClass(className);
return this as T;
} /// <summary>
/// 删除class属性值
/// </summary>
/// <param name="className"></param>
/// <returns></returns>
public T RemoveClass(string className)
{
if (string.IsNullOrWhiteSpace(className))
{
return this as T;
} if (!ContainsClass(className))
{
return this as T;
} var classs = TagBuilder.Attributes["class"]; var classArray = classs.Split(new[] { ' ' }, StringSplitOptions.RemoveEmptyEntries)
.Where(i => string.Equals(i, className, StringComparison.OrdinalIgnoreCase)); TagBuilder.Attributes["class"] = string.Join(" ", classArray);
return this as T;
} /// <summary>
/// 合并class属性值
/// </summary>
/// <param name="className"></param>
/// <returns></returns>
public T ToggleClass(string className)
{
if (string.IsNullOrWhiteSpace(className))
{
return this as T;
} return ContainsClass(className) ? RemoveClass(className) : AddClass(className);
}
#endregion #region 抽象方法
/// <summary>
/// 返回HTML编码的字符串(子类必须重写)
/// </summary>
/// <returns></returns>
public abstract string ToHtmlString();
#endregion
}
}

  

  再看看具体是如何实现的?

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Web.Mvc;
using System.Web.Mvc.Html; namespace NS.Utility.EasyUI
{
public class ComboBoxBuilder : TagElementBuilder<ComboBoxBuilder>
{
#region 私有变量
private bool required = false;
private string valueField = string.Empty;
private string textField = string.Empty;
private string groupField = string.Empty;
private string groupFormatter = string.Empty;
private EasyUIComboBoxMode mode = EasyUIComboBoxMode.local;
private string url = string.Empty;
private EasyUIComboBoxMethod method = EasyUIComboBoxMethod.post;
private string data = string.Empty;
private string filter = string.Empty;
private string formatter = string.Empty;
private string loader = string.Empty;
private string loadFilter = string.Empty; private string onBeforeLoad = string.Empty;
private string onLoadSuccess = string.Empty;
private string onLoadError = string.Empty;
private string onSelect = string.Empty;
private string onUnselect = string.Empty;
#endregion #region 公有方法
public ComboBoxBuilder Required(bool required)
{
this.required = required;
return this;
}
public ComboBoxBuilder ValueField(string valueField)
{
this.valueField = valueField;
return this;
}
public ComboBoxBuilder TextField(string textField)
{
this.textField = textField;
return this;
}
public ComboBoxBuilder GroupField(string groupField)
{
this.groupField = groupField;
return this;
}
public ComboBoxBuilder GroupFormatter(string groupFormatter)
{
this.groupFormatter = groupFormatter;
return this;
}
public ComboBoxBuilder Mode(EasyUIComboBoxMode mode)
{
this.mode = mode;
return this;
}
public ComboBoxBuilder Url(string url)
{
this.url = url;
return this;
}
public ComboBoxBuilder Method(EasyUIComboBoxMethod method)
{
this.method = method;
return this;
}
public ComboBoxBuilder Data(string data)
{
this.data = data;
return this;
}
public ComboBoxBuilder Filter(string filter)
{
this.filter = filter;
return this;
}
public ComboBoxBuilder Formatter(string formatter)
{
this.formatter = formatter;
return this;
}
public ComboBoxBuilder Loader(string loader)
{
this.loader = loader;
return this;
}
public ComboBoxBuilder LoadFilter(string loadFilter)
{
this.loadFilter = loadFilter;
return this;
} public ComboBoxBuilder OnBeforeLoad(string onBeforeLoad)
{
this.onBeforeLoad = onBeforeLoad;
return this;
}
public ComboBoxBuilder OnLoadSuccess(string onLoadSuccess)
{
this.onLoadSuccess = onLoadSuccess;
return this;
}
public ComboBoxBuilder OnLoadError(string onLoadError)
{
this.onLoadError = onLoadError;
return this;
}
public ComboBoxBuilder OnSelect(string onSelect)
{
this.onSelect = onSelect;
return this;
}
public ComboBoxBuilder OnUnselect(string onUnselect)
{
this.onUnselect = onUnselect;
return this;
}
#endregion #region TagElementBuilder 重写属性和方法
public override string TagName
{
get { return "input"; }
} public override string ToHtmlString()
{
//参考格式:<input id="cc" class="easyui-combobox" name="dept" data-options="valueField:'id',textField:'text',url:'get_data.php'" /> //拼接class属性值
TagBuilder.AddCssClass("easyui-combobox"); //拼接data-options属性值
List<string> listAttri = new List<string>(); //开始拼接各种属性值
if (this.required == true)
{
//是否必输项
listAttri.Add(string.Format("required:{0}", this.required.ToString().ToLower()));
}
if (string.IsNullOrEmpty(this.valueField) == false)
{
listAttri.Add(string.Format("valueField:'{0}'", this.valueField));
}
if (string.IsNullOrEmpty(this.textField) == false)
{
listAttri.Add(string.Format("textField:'{0}'", this.textField));
}
if (string.IsNullOrEmpty(this.groupField) == false)
{
}
if (this.mode != EasyUIComboBoxMode.local)
{
}
if (string.IsNullOrEmpty(this.url) == false)
{
listAttri.Add(string.Format("url:'{0}'", this.url));
}
if (this.method == EasyUIComboBoxMethod.get)
{
}
if (string.IsNullOrEmpty(this.data) == false)
{
}
if (string.IsNullOrEmpty(this.filter) == false)
{
}
if (string.IsNullOrEmpty(this.formatter) == false)
{
}
if (string.IsNullOrEmpty(this.loader) == false)
{
}
if (string.IsNullOrEmpty(this.loadFilter) == false)
{
} //开始拼接各种事件
if (string.IsNullOrEmpty(this.onBeforeLoad) == false)
{
}
if (string.IsNullOrEmpty(this.onLoadSuccess) == false)
{
}
if (string.IsNullOrEmpty(this.onLoadError) == false)
{
}
if (string.IsNullOrEmpty(this.onSelect) == false)
{
}
if (string.IsNullOrEmpty(this.onUnselect) == false)
{
} string dataOptions = string.Join(",", listAttri.ToArray());
TagBuilder.Attributes.Add("data-options", dataOptions); var builder = new StringBuilder();
var tagHtml = TagBuilder.ToString(TagRenderMode.SelfClosing);
builder.AppendLine(tagHtml); return new MvcHtmlString(builder.ToString()).ToHtmlString();
}
#endregion
}
}

  看,其实并不复杂吧,完整源码是必须提供的

源码下载方式
1,关注微信公众号:小特工作室(也可直接扫描签名处二维码)
2,发送:示例4011
即可下载 

基于JQuery EasyUI的WebMVC控件封装(含源码)的更多相关文章

  1. jquery easyui datebox 时间控件默认显示当前日期的实现方法

    jquery easyui datebox 时间控件默认显示当前日期的实现方法 直接class easyui-datebox后添加一个value="true"就可以

  2. jQuery EasyUI动态添加控件或者ajax加载页面后不能自动渲染问题的解决方法

    博客分类: jquery-easyui jQueryAjax框架HTML  现象: AJAX返回的html无法做到自动渲染为EasyUI的样式.比如:class="easyui-layout ...

  3. 国籍控件(js源码)

    国籍控件(js源码) 一直苦于没有好的国籍控件可以用,于是抽空写了一个国籍控件,现分享给大家. 主要功能和界面介绍 国籍控件主要支持中文.英文过滤以及键盘上下事件. 源码介绍 国籍控件核心是两个文件, ...

  4. 在Winform窗体中使用WPF控件(附源码)

    原文:在Winform窗体中使用WPF控件(附源码) 今天是礼拜6,下雨,没有外出,闲暇就写一篇博文讲下如何在Winform中使用WPF控件.原有是我在百度上搜索相关信息无果,遂干脆动手自己实现. W ...

  5. Jquery easyui的validatebox控件和正则表达式

    http://blog.csdn.net/dandanzmc/article/details/36421465 仔细观察jquery.validatebox.js文件,会发现它的验证其实还是采用的正则 ...

  6. Python 基于python实现的http接口自动化测试框架(含源码)

    基于python实现的http+json协议接口自动化测试框架(含源码) by:授客 QQ:1033553122      欢迎加入软件性能测试交流 QQ群:7156436  由于篇幅问题,采用百度网 ...

  7. 打造基于jQuery的日期选择控件

    终于把jQuery拼写正确了哈,哈哈javascript也是区分大小写的,所以确实不能写错,今天我来和大家分享的是日期选择控件的实现,功能也许不够强大,但是能够满足需求. 我之前也写过(正确的说是改过 ...

  8. 基于Jquery的文本提示控件 poshytip

    Html中,如设置了title的属性,则当鼠标在该对象上面短暂的停留时,会显示预设的文本提示,但,这些效果只会短暂的显示,一会就会消失,又要重新把鼠标移出再移回来才被显示,样式也无法重写,实在是恼人之 ...

  9. 福利到~分享一个基于jquery的智能提示控件intellSeach.js

    一.需求 我们经常会遇到[站内搜索]的需求,为了提高用户体验,我们希望能做到像百度那样的即时智能提示.例如:某公司人事管理系统,想搜索李XX,只要输入“李”,系统自然会提示一些姓李的员工,这样方便用户 ...

随机推荐

  1. Apache Spark 2.2.0 中文文档 - 集群模式概述 | ApacheCN

    集群模式概述 该文档给出了 Spark 如何在集群上运行.使之更容易来理解所涉及到的组件的简短概述.通过阅读 应用提交指南 来学习关于在集群上启动应用. 组件 Spark 应用在集群上作为独立的进程组 ...

  2. C++ 虚函数 、纯虚函数、接口的实用方法和意义

    也许之前我很少写代码,更很少写面向对象的代码,即使有写多半也很容易写回到面向过程的老路上去.在写面向过程的代码的时候,根本不管什么函数重载和覆盖,想到要什么功能就变得法子的换个函数名字,心里想想:反正 ...

  3. The Nerd Factor SPOJ - MYQ5

    The Nerd Factor Time Limit: 1000MS   Memory Limit: Unknown   64bit IO Format: %lld & %llu [Submi ...

  4. SUM游戏

    题意:就是有一个长度为n的整数序列,两个游戏者A和B轮流取数,A先取.每次玩家只能从左端或者右端取任意数量个数,但不能两端都取. 所有数都被取走后游戏结束,然后统计每个人取走的所有数之和,作为各自的得 ...

  5. 醒醒吧!互联网的真正未来不是AI,更不是VR,AR,而是区块链

    这些力量并非命运,而是轨迹.他们提供的并不是我们将去向何方的预测,而是告诉我们,在不远的将来,我们会向那个方向前行,必然而然. ---凯文•凯利 文字与货币 人类在演化过程中,凭借智慧创造了无数事物, ...

  6. jdbc学习总结

    jdbc学习总结:   一.简介: jdbc,直译为java连接数据库.实际为java为很好的操作数据库而提供的一套接口,接口的实现(即驱动)由各个数据库厂商提供.   二.知识要点: 连接5要素,3 ...

  7. strut2-学习笔记(二)

     Struts2学习笔记(二) 1. 自定义结果视图的类型(结果视图类型的应用) CAPTCHA图像(随机验证码图像) 实现步骤: (1)编写一个类实现com.opensymphony.xwork ...

  8. PDO浅谈之php连接mysql

    一.首先我们先说一下什么是pdo?  百科上说 PDO扩展为PHP访问数据库定义了一个轻量级的.一致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函数执行查询和获取数 ...

  9. J2EE走向成功路-02-Struts2 配置(Maven)

    在上一篇中,介绍了使用jar包搭建Struts2框架,这一篇中来介绍一下在Maven环境下搭建Struts2框架,主要为配置Maven. 1.下载Maven,官网:http://maven.apach ...

  10. asp.net mvc webapi 实用的接口加密方法

    在很多项目中,因为webapi是对外开放的,这个时候,我们就要得考虑接口交换数据的安全性. 安全机制也比较多,如andriod与webapi 交换数据的时候,可以走双向证书方法,但是开发成本比较大, ...