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

(2)無值時的情況

以上所述是小編給大家介紹的jQuery EasyUI 組件加上“清除”功能實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
jQuery+php實時獲取及響應(yīng)文本框輸入內(nèi)容的方法
這篇文章主要介紹了jQuery+php實時獲取及響應(yīng)文本框輸入內(nèi)容的方法,涉及jQuery響應(yīng)鍵盤事件及ajax調(diào)用php文件針對輸入內(nèi)容的處理與回調(diào)相關(guān)技巧,非常簡單易懂,需要的朋友可以參考下2016-05-05
jquery導(dǎo)航制件jquery鼠標(biāo)經(jīng)過變色效果示例
這篇文章主要介紹了jquery鼠標(biāo)經(jīng)過變色效果代碼,大家參考使用吧2013-12-12
jQuery動態(tài)加載css文件實現(xiàn)方法
使用jQuery來加載一個外部的 css 文件,首先創(chuàng)建一個 link 元素,并將它添加到 標(biāo)記中即可。那么基于jquery代碼如何實現(xiàn)呢?下面小編給大家介紹jQuery動態(tài)加載css文件實現(xiàn)方法,需要的朋友參考下吧2016-06-06
jquery ajax jsonp跨域調(diào)用實例代碼
今天研究了AJAX使用JSONP進行跨域調(diào)用的方法,發(fā)現(xiàn)使用GET方式和POST方式都可以進行跨域調(diào)用,這里簡單分享下,方便需要的朋友2013-12-12
Jquery UI實現(xiàn)一次拖拽多個選中的元素操作
這篇文章主要介紹了Jquery UI實現(xiàn)一次拖拽多個選中的元素操作,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10

