為Jquery EasyUI 組件加上清除功能的方法(詳解)
1、背景
在使用 EasyUI 各表單組件時(shí),尤其是使用 ComboBox(下拉列表框)、DateBox(日期輸入框)、DateTimeBox(日期時(shí)間輸入框)這三個(gè)組件時(shí),經(jīng)常有這樣的需求,下拉框或日期只允許選擇、不允許手動(dòng)輸入,這時(shí)只要在組件選項(xiàng)中加入 editable:false 就可以實(shí)現(xiàn),但有一個(gè)問(wèn)題,就是:一旦選擇了,沒(méi)辦法清空。經(jīng)過(guò)研究,可以用一個(gè)變通的解決方案:給組件加上一個(gè)“清除”按鈕,當(dāng)有值是,顯示按鈕,點(diǎn)擊按鈕可清空值,當(dāng)無(wú)值是,隱藏按鈕。
2、函數(shù)定義
定義JS方法,為 EasyUI 中一些常用組件添加'清除'按鈕及功能。共計(jì)6個(gè):
/*
* 為‘文本框'列表添加‘清除'圖標(biāo)
* 該實(shí)現(xiàn)使用了 onChange 事件,如果用戶需要該事件,可傳入自定義函數(shù),會(huì)自動(dòng)回調(diào) 。
*/
function addClear4TextBox(theId,onChangeFun)
{
var theObj = $(theId);
//根據(jù)當(dāng)前值,確定是否顯示清除圖標(biāo)
var showIcon = function(){
var icon = theObj.textbox('getIcon',0);
if (theObj.textbox('getValue')){
icon.css('visibility','visible');
} else {
icon.css('visibility','hidden');
}
};
theObj.textbox({
//添加清除圖標(biāo)
icons:[{
iconCls:'icon-clear',
handler: function(e){
theObj.textbox('clear');
}
}],
//值改變時(shí),根據(jù)值,確定是否顯示清除圖標(biāo)
onChange:function(){
if(onChangeFun)
{
onChangeFun();
}
showIcon();
}
});
//根據(jù)目前值,確定是否顯示清除圖標(biāo)
showIcon();
}
/*
* 為‘下拉列表框'添加‘清除'圖標(biāo)
* 該實(shí)現(xiàn)使用了 onChange 事件,如果用戶需要該事件,可傳入自定義函數(shù),會(huì)自動(dòng)回調(diào) 。
*/
function addClear4Combobox(theId,onChangeFun)
{
var theObj = $(theId);
//根據(jù)當(dāng)前值,確定是否顯示清除圖標(biāo)
var showIcon = function(){
var icon = theObj.combobox('getIcon',0);
if (theObj.combobox('getValue')){
icon.css('visibility','visible');
} else {
icon.css('visibility','hidden');
}
};
theObj.combobox({
//添加清除圖標(biāo)
icons:[{
iconCls:'icon-clear',
handler: function(e){
theObj.combobox('clear');
}
}],
//值改變時(shí),根據(jù)值,確定是否顯示清除圖標(biāo)
onChange:function(){
if(onChangeFun)
{
onChangeFun();
}
showIcon();
}
});
//初始化確認(rèn)圖標(biāo)顯示
showIcon();
}
/*
* 為‘?dāng)?shù)據(jù)表格下拉框'添加‘清除'圖標(biāo)
* 該實(shí)現(xiàn)使用了 onChange 事件,如果用戶需要該事件,可傳入自定義函數(shù),會(huì)自動(dòng)回調(diào) 。
*/
function addClear4Combogrid(theId,onChangeFun)
{
var theObj = $(theId);
//根據(jù)當(dāng)前值,確定是否顯示清除圖標(biāo)
var showIcon = function(){
var icon = theObj.combogrid('getIcon',0);
if (theObj.combogrid('getValue')){
icon.css('visibility','visible');
} else {
icon.css('visibility','hidden');
}
};
theObj.combogrid({
//添加清除圖標(biāo)
icons:[{
iconCls:'icon-clear',
handler: function(e){
theObj.combogrid('clear');
}
}],
//值改變時(shí),根據(jù)值,確定是否顯示清除圖標(biāo)
onChange:function(){
if(onChangeFun)
{
onChangeFun();
}
showIcon();
}
});
//初始化確認(rèn)圖標(biāo)顯示
showIcon();
}
/*
* 為‘?dāng)?shù)值輸入框'添加‘清除'圖標(biāo)
* 該實(shí)現(xiàn)使用了 onChange 事件,如果用戶需要該事件,可傳入自定義函數(shù),會(huì)自動(dòng)回調(diào) 。
*/
function addClear4Numberbox(theId,onChangeFun)
{
var theObj = $(theId);
//根據(jù)當(dāng)前值,確定是否顯示清除圖標(biāo)
var showIcon = function(){
var icon = theObj.numberbox('getIcon',0);
if (theObj.numberbox('getValue')){
icon.css('visibility','visible');
} else {
icon.css('visibility','hidden');
}
};
theObj.numberbox({
//添加清除圖標(biāo)
icons:[{
iconCls:'icon-clear',
handler: function(e){
theObj.numberbox('clear');
}
}],
//值改變時(shí),根據(jù)值,確定是否顯示清除圖標(biāo)
onChange:function(){
if(onChangeFun)
{
onChangeFun();
}
showIcon();
}
});
//初始化確認(rèn)圖標(biāo)顯示
showIcon();
}
/*
* 為‘日期選擇框'添加‘清除'圖標(biāo)
* 該實(shí)現(xiàn)使用了 onChange 事件,如果用戶需要該事件,可傳入自定義函數(shù),會(huì)自動(dòng)回調(diào) 。
*/
function addClear4Datebox(theId,onChangeFun)
{
var theObj = $(theId);
//根據(jù)當(dāng)前值,確定是否顯示清除圖標(biāo)
var showIcon = function(){
var icon = theObj.datebox('getIcon',0);
if (theObj.datebox('getValue')){
icon.css('visibility','visible');
} else {
icon.css('visibility','hidden');
}
};
theObj.datebox({
//添加清除圖標(biāo)
icons:[{
iconCls:'icon-clear',
handler: function(e){
theObj.datebox('clear');
}
}],
//值改變時(shí),根據(jù)值,確定是否顯示清除圖標(biāo)
onChange:function(){
if(onChangeFun)
{
onChangeFun();
}
showIcon();
}
});
//初始化確認(rèn)圖標(biāo)顯示
showIcon();
}
/*
* 為‘日期時(shí)間選擇框'添加‘清除'圖標(biāo)
* 該實(shí)現(xiàn)使用了 onChange 事件,如果用戶需要該事件,可傳入自定義函數(shù),會(huì)自動(dòng)回調(diào) 。
*/
function addClear4Datetimebox(theId,onChangeFun)
{
var theObj = $(theId);
//根據(jù)當(dāng)前值,確定是否顯示清除圖標(biāo)
var showIcon = function(){
var icon = theObj.datetimebox('getIcon',0);
if (theObj.datetimebox('getValue')){
icon.css('visibility','visible');
} else {
icon.css('visibility','hidden');
}
};
theObj.datetimebox({
//添加清除圖標(biāo)
icons:[{
iconCls:'icon-clear',
handler: function(e){
theObj.datetimebox('clear');
}
}],
//值改變時(shí),根據(jù)值,確定是否顯示清除圖標(biāo)
onChange:function(){
if(onChangeFun)
{
onChangeFun();
}
showIcon();
}
});
//初始化確認(rèn)圖標(biāo)顯示
showIcon();
}
3、使用
用法格式如下:
(1)addClear4TextBox("#name",nameChangeDo); //文本框,同時(shí)傳入了回調(diào)函數(shù)
(2)addClear4Combobox("#state\\.id"); //下拉列表框
(3)addClear4Combogrid("#type\\.id"); //數(shù)據(jù)表格下拉框
(4)addClear4Numberbox("#intNum2"); //數(shù)值輸入框
(5)addClear4Datebox("#theDate2"); //日期選擇框
(6)addClear4Datetimebox("#theTime2"); //日期選擇框
注:函數(shù)的實(shí)現(xiàn)使用了 onChange 事件,如果需要使用該事件執(zhí)行某些操作,可傳入自定義函數(shù),會(huì)自動(dòng)回調(diào) ,參見(jiàn)(1)。
<script>
//名稱改變時(shí)執(zhí)行的一些操作。(演示清除操作回調(diào))
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)有值時(shí)的情況(其中 類型 是數(shù)據(jù)列表下拉框)

(2)無(wú)值時(shí)的情況

以上這篇為Jquery EasyUI 組件加上清除功能的方法(詳解)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JQuery驗(yàn)證jsp頁(yè)面屬性是否為空(實(shí)例代碼)
JQuery驗(yàn)證jsp頁(yè)面屬性是否為空的實(shí)例代碼。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11
jquery formValidator插件ajax驗(yàn)證 內(nèi)容不做任何修改再離開(kāi)提示錯(cuò)誤的bug解決方法
query formValidator插件非常好用,但是有一個(gè)嚴(yán)重的Bug,在使用ajax驗(yàn)證的時(shí)候,如果輸入框的內(nèi)容已經(jīng)存在,把鼠標(biāo)放到輸入框,不做任何修改再離開(kāi),則會(huì)提示錯(cuò)誤,很是郁悶2013-01-01
js判斷復(fù)選框是否選中的方法示例【基于jQuery】
這篇文章主要介紹了js判斷復(fù)選框是否選中的方法,結(jié)合實(shí)例形式分析了基于jQuery實(shí)現(xiàn)的復(fù)選框選中判斷相關(guān)操作技巧,需要的朋友可以參考下2019-10-10
利用jquery動(dòng)畫特效和css打造的側(cè)邊彈出垂直導(dǎo)航
這是一款側(cè)邊彈出垂直導(dǎo)航,整個(gè)彈出過(guò)程比較流暢,而且代碼很簡(jiǎn)單,需要的朋友可以參考下2014-04-04
jQuery基于ajax實(shí)現(xiàn)星星評(píng)論代碼
這篇文章主要介紹了jQuery基于ajax實(shí)現(xiàn)星星評(píng)論代碼,可實(shí)現(xiàn)實(shí)時(shí)顯示評(píng)論效果的功能,基于Ajax實(shí)現(xiàn),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-08-08
JQuery CheckBox(復(fù)選框)操作方法匯總
這篇文章主要介紹了JQuery CheckBox(復(fù)選框)操作方法匯總,本文講解了獲取單個(gè)checkbox選中項(xiàng)、獲取多個(gè)checkbox選中項(xiàng)、設(shè)置第一個(gè)checkbox 為選中值、設(shè)置最后一個(gè)checkbox為選中值等內(nèi)容,需要的朋友可以參考下2015-04-04
jquery keypress,keyup,onpropertychange鍵盤事件
項(xiàng)目所需,在試圖用js實(shí)現(xiàn)這樣的功能:文本框失去焦點(diǎn)時(shí),判斷輸入字符串的長(zhǎng)度,以驗(yàn)證是否超出范圍,超出范圍則自動(dòng)截取。2010-06-06

