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)。
<script>
//名称改变时执行的一些操作。(演示清除操作回调)
var nameChangeDo = function(){
//alert("改变了...");
}
$(function(){
addClear4TextBox("#code");
addClear4TextBox("#name",nameChangeDo);
addClear4Combobox("#city");
addClear4Combobox("#state\\.id");
addClear4Combogrid("#type\\.id");
addClear4Combobox("#hobby");
addClear4Numberbox("#intNum2");
addClear4Numberbox("#doubleNum1");
addClear4Numberbox("#doubleNum2");
addClear4Datebox("#theDate2");
addClear4Datetimebox("#theTime2");
addClear4TextBox("#remark");
});
</script>
4、效果展示
(1)有值时的情况(其中 类型 是数据列表下拉框)
(2)无值时的情况
以上所述是小编给大家介绍的jQuery EasyUI 组件加上“清除”功能实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# easyui组件
# jquery
# easyui
# 组件
# Jquery组件easyUi实现手风琴(折叠面板)示例
# Jquery组件easyUi实现选项卡切换示例
# jQuery EasyUI基础教程之EasyUI常用组件(推荐)
# jQuery EasyUI框架中的Datagrid数据表格组件结构详解
# Jquery下EasyUI组件中的DataGrid结果集清空方法
# 回调
# 自定义
# 使用了
# 输入框
# 下拉框
# 小编
# 清空
# 文本框
# 尤其是
# 在此
# 可以用
# 没办法
# 给大家
# 表单
# 这三个
# 所述
# 给我留言
# 感谢大家
# 就可以
# 只允许
相关文章:
c# await 一个已经完成的Task会发生什么
建站之星2.7模板:企业网站建设与h5定制设计专题
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
建站主机默认首页配置指南:核心功能与访问路径优化
如何在服务器上配置二级域名建站?
免费公司网站制作软件,如何申请免费主页空间做自己的网站?
,怎么用自己头像做动态表情包?
韩国服务器如何优化跨境访问实现高效连接?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
网站制作壁纸教程视频,电脑壁纸网站?
定制建站流程步骤详解:一站式方案设计与开发指南
建站主机与服务器功能差异如何区分?
如何通过FTP服务器快速搭建网站?
建站之星logo尺寸如何设置最合适?
我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?
营销式网站制作方案,销售哪个网站招聘效果最好?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
成都网站制作公司哪家好,四川省职工服务网是做什么用?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
网站图片在线制作软件,怎么在图片上做链接?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
济南企业网站制作公司,济南社保单位网上缴费步骤?
云南网站制作公司有哪些,云南最好的招聘网站是哪个?
如何基于PHP生成高效IDC网络公司建站源码?
如何在景安云服务器上绑定域名并配置虚拟主机?
公司网站制作需要多少钱,找人做公司网站需要多少钱?
网站制作企业,网站的banner和导航栏是指什么?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
简易网站制作视频教程,使用记事本编写一个简单的网页html文件?
如何使用Golang安装API文档生成工具_快速生成接口文档
建站之星下载版如何获取与安装?
高端智能建站公司优选:品牌定制与SEO优化一站式服务
如何在阿里云部署织梦网站?
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
css网站制作参考文献有哪些,易聊怎么注册?
教程网站设计制作软件,怎么创建自己的一个网站?
广州商城建站系统开发成本与周期如何控制?
h5在线制作网站电脑版下载,h5网页制作软件?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
如何在西部数码注册域名并快速搭建网站?
如何选择可靠的免备案建站服务器?
建站之星如何配置系统实现高效建站?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
php json中文编码为null的解决办法
如何生成腾讯云建站专用兑换码?
*请认真填写需求信息,我们会在24小时内与您取得联系。