博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
为JQuery EasyUI 表单组件加上“清除”功能
阅读量:4908 次
发布时间:2019-06-11

本文共 6133 字,大约阅读时间需要 20 分钟。

1、背景

    在使用 EasyUI 各表单组件时,尤其是使用 ComboBox(下拉列表框)、DateBox(日期输入框)、DateTimeBox(日期时间输入框)这三个组件时,经常有这样的需求,下拉框或日期只允许选择、不允许手动输入,这时只要在组件选项中加入 editable:false 就可以实现,但有一个问题,就是:一旦选择了,没办法清空。经过研究,可以用一个变通的解决方案:给组件加上一个“清除”按钮,当有值是,显示按钮,点击按钮可清空值,当无值是,隐藏按钮。

 

2、函数定义

定义JS方法,为 EasyUI 中一些常用组件添加'清除'按钮及功能。共计6个: 

/* * 为‘文本框’列表添加‘清除’图标 * 该实现使用了 onChange 事件,如果用户需要该事件,可传入自定义函数,会自动回调 。 */function addClear4TextBox(theId,onChangeFun){    var theObj = $(theId);        //根据当前值,确定是否显示清除图标    var showIcon = function(){                var icon = theObj.textbox('getIcon',0);        if (theObj.textbox('getValue')){            icon.css('visibility','visible');        } else {            icon.css('visibility','hidden');        }    };        theObj.textbox({        //添加清除图标        icons:[{            iconCls:'icon-clear',            handler: function(e){                theObj.textbox('clear');            }        }],                //值改变时,根据值,确定是否显示清除图标        onChange:function(){            if(onChangeFun)            {                onChangeFun();            }            showIcon();        }            });            //根据目前值,确定是否显示清除图标    showIcon();}/* * 为‘下拉列表框’添加‘清除’图标 * 该实现使用了 onChange 事件,如果用户需要该事件,可传入自定义函数,会自动回调 。 */function addClear4Combobox(theId,onChangeFun){    var theObj = $(theId);        //根据当前值,确定是否显示清除图标    var showIcon = function(){                var icon = theObj.combobox('getIcon',0);        if (theObj.combobox('getValue')){            icon.css('visibility','visible');        } else {            icon.css('visibility','hidden');        }    };        theObj.combobox({        //添加清除图标        icons:[{            iconCls:'icon-clear',            handler: function(e){                theObj.combobox('clear');            }        }],                //值改变时,根据值,确定是否显示清除图标        onChange:function(){            if(onChangeFun)            {                onChangeFun();            }            showIcon();        }            });            //初始化确认图标显示    showIcon();}/* * 为‘数据表格下拉框’添加‘清除’图标 * 该实现使用了 onChange 事件,如果用户需要该事件,可传入自定义函数,会自动回调 。 */function addClear4Combogrid(theId,onChangeFun){    var theObj = $(theId);        //根据当前值,确定是否显示清除图标    var showIcon = function(){                var icon = theObj.combogrid('getIcon',0);        if (theObj.combogrid('getValue')){            icon.css('visibility','visible');        } else {            icon.css('visibility','hidden');        }    };        theObj.combogrid({        //添加清除图标        icons:[{            iconCls:'icon-clear',            handler: function(e){                theObj.combogrid('clear');            }        }],                //值改变时,根据值,确定是否显示清除图标        onChange:function(){            if(onChangeFun)            {                onChangeFun();            }            showIcon();        }            });            //初始化确认图标显示    showIcon();}/* * 为‘数值输入框’添加‘清除’图标 * 该实现使用了 onChange 事件,如果用户需要该事件,可传入自定义函数,会自动回调 。 */function addClear4Numberbox(theId,onChangeFun){    var theObj = $(theId);        //根据当前值,确定是否显示清除图标    var showIcon = function(){                var icon = theObj.numberbox('getIcon',0);        if (theObj.numberbox('getValue')){            icon.css('visibility','visible');        } else {            icon.css('visibility','hidden');        }    };        theObj.numberbox({        //添加清除图标        icons:[{            iconCls:'icon-clear',            handler: function(e){                theObj.numberbox('clear');            }        }],                //值改变时,根据值,确定是否显示清除图标        onChange:function(){            if(onChangeFun)            {                onChangeFun();            }            showIcon();        }            });            //初始化确认图标显示    showIcon();}/* * 为‘日期选择框’添加‘清除’图标 * 该实现使用了 onChange 事件,如果用户需要该事件,可传入自定义函数,会自动回调 。 */function addClear4Datebox(theId,onChangeFun){    var theObj = $(theId);        //根据当前值,确定是否显示清除图标    var showIcon = function(){                var icon = theObj.datebox('getIcon',0);        if (theObj.datebox('getValue')){            icon.css('visibility','visible');        } else {            icon.css('visibility','hidden');        }    };        theObj.datebox({        //添加清除图标        icons:[{            iconCls:'icon-clear',            handler: function(e){                theObj.datebox('clear');            }        }],                //值改变时,根据值,确定是否显示清除图标        onChange:function(){            if(onChangeFun)            {                onChangeFun();            }            showIcon();        }            });            //初始化确认图标显示    showIcon();}/* * 为‘日期时间选择框’添加‘清除’图标 * 该实现使用了 onChange 事件,如果用户需要该事件,可传入自定义函数,会自动回调 。 */function addClear4Datetimebox(theId,onChangeFun){    var theObj = $(theId);        //根据当前值,确定是否显示清除图标    var showIcon = function(){                var icon = theObj.datetimebox('getIcon',0);        if (theObj.datetimebox('getValue')){            icon.css('visibility','visible');        } else {            icon.css('visibility','hidden');        }    };        theObj.datetimebox({        //添加清除图标        icons:[{            iconCls:'icon-clear',            handler: function(e){                theObj.datetimebox('clear');            }        }],                //值改变时,根据值,确定是否显示清除图标        onChange:function(){            if(onChangeFun)            {                onChangeFun();            }            showIcon();        }            });            //初始化确认图标显示    showIcon();}

 

3、使用

用法格式如下:

(1)addClear4TextBox("#name",nameChangeDo); //文本框,同时传入了回调函数

(2)addClear4Combobox("#state\\.id"); //下拉列表框
(3)addClear4Combogrid("#type\\.id"); //数据表格下拉框
(4)addClear4Numberbox("#intNum2"); //数值输入框
(5)addClear4Datebox("#theDate2"); //日期选择框
(6)addClear4Datetimebox("#theTime2"); //日期选择框
注:函数的实现使用了 onChange 事件,如果需要使用该事件执行某些操作,可传入自定义函数,会自动回调 ,参见(1)。

 

 

4、效果展示

(1)有值时的情况(其中 类型 是数据列表下拉框)

 

(2)无值时的情况

 

 

5、进一步扩展

增加自动添加“清除”功能的函数,省去每个组件手动添加的麻烦。

(1)自动添加函数定义

//自动填加清除功能 (组件需要增加 addClear属性 )function autoAddClear(){    var arr = $("input[addClear]");    for(var i=0;i

 

(2)使用时,各组件上添加 addClear 属性。

 

 

(3)使用自动添加 

$(function(){    autoAddClear(); //为各组件自动填加‘清除’功能(组件需要增加 addClear属性 )    addClear4TextBox("#name",nameChangeDo); //对于需要使用OnChange事件的组件,单独手动填加});

 

转载于:https://www.cnblogs.com/rulian/p/6690326.html

你可能感兴趣的文章
【转】七个受用一生的心理寓言
查看>>
nginx
查看>>
自制密码管理系统
查看>>
成功者所应具有的九大素质
查看>>
学习爬虫:《Python网络数据采集》中英文PDF+代码
查看>>
多态、抽象类、接口、区别(java基础知识九)
查看>>
.NET笔试题集(二)
查看>>
原码, 反码, 补码 详解
查看>>
BZOJ4154 : [Ipsc2015]Generating Synergy
查看>>
我的一个小App——谈天气
查看>>
【DevExpress v17.2新功能预告】DevExtreme TreeList
查看>>
Fitnesse框架介绍(一)
查看>>
Codeforces Round #FF (Div. 2) 题解
查看>>
Mysql Programming CS 155P笔记(三)
查看>>
我的感情,仍是如此,卦卦如此
查看>>
这样一套操作要练习多久
查看>>
linux系统管理(1)之 内核编译选项查看
查看>>
HDMI中checksum计算法
查看>>
Android入门之旅3—ubuntu11.4上通过adb连接M9手机
查看>>
将eclipse上的web项目部署到Tomcat服务器上经验总结
查看>>