基于jquery的監(jiān)控數(shù)據(jù)是否發(fā)生改變
更新時間:2011年04月11日 20:46:54 作者:
在實際開發(fā)中經(jīng)常會遇到數(shù)據(jù)沒發(fā)生改變是,由于用戶不小心點擊保存,這樣導(dǎo)致數(shù)據(jù)庫的日志增大;還有數(shù)據(jù)填寫好后,忘了添加保存直接關(guān)閉頁面離開。
這樣之前的功夫又白費了。解決這些問題的辦法就是:監(jiān)控頁面數(shù)據(jù)是否發(fā)生變化。如果發(fā)生變化,提示用戶保存。如果數(shù)據(jù)未發(fā)生變化。當(dāng)我們點擊保存時,也不需要提交到數(shù)據(jù)庫。
接下來看看解決辦法:
///<reference path="jquery-1.3.2-vsdoc2.js" />
(function($) {
var pageDataChange = false //默認(rèn)標(biāo)識頁面數(shù)據(jù)未發(fā)生改變
/*監(jiān)控頁面數(shù)據(jù)是否發(fā)生變化*/
$.fn.MonitorDataChange = function(options) {
var tagName = new Array('Input', 'Select', 'Textarea');
var ctrlIds = [];
var deafult = {
arrTags: tagName, //需監(jiān)控控件的tagName屬性數(shù)組
arrCtrls: ctrlIds //不監(jiān)控的控件ID
};
var ops = $.extend(deafult, options);
for (var i = 0; i < ops.arrTags.length; i++) {
$(ops.arrTags[i]).each(function() {
if (ops.arrCtrls.length == 0) {
$(this).bind('change', function() {
pageDataChange = true;
});
}
else {
var flag = false;
for (var j = 0; j < ops.arrCtrls.length; j++) {
if ($(this).attr('id') == ops.arrCtrls[j]) {
flag = true;
break;
}
}
if (!flag) {
$(this).bind('change', function() {
pageDataChange = true;
});
}
}
});
}
return this;
};
/*返回頁面數(shù)據(jù)是否發(fā)生變化*/
$.fn.getValue = function() {
return pageDataChange;
};
})(jQuery);
接下來看看解決辦法:
復(fù)制代碼 代碼如下:
///<reference path="jquery-1.3.2-vsdoc2.js" />
(function($) {
var pageDataChange = false //默認(rèn)標(biāo)識頁面數(shù)據(jù)未發(fā)生改變
/*監(jiān)控頁面數(shù)據(jù)是否發(fā)生變化*/
$.fn.MonitorDataChange = function(options) {
var tagName = new Array('Input', 'Select', 'Textarea');
var ctrlIds = [];
var deafult = {
arrTags: tagName, //需監(jiān)控控件的tagName屬性數(shù)組
arrCtrls: ctrlIds //不監(jiān)控的控件ID
};
var ops = $.extend(deafult, options);
for (var i = 0; i < ops.arrTags.length; i++) {
$(ops.arrTags[i]).each(function() {
if (ops.arrCtrls.length == 0) {
$(this).bind('change', function() {
pageDataChange = true;
});
}
else {
var flag = false;
for (var j = 0; j < ops.arrCtrls.length; j++) {
if ($(this).attr('id') == ops.arrCtrls[j]) {
flag = true;
break;
}
}
if (!flag) {
$(this).bind('change', function() {
pageDataChange = true;
});
}
}
});
}
return this;
};
/*返回頁面數(shù)據(jù)是否發(fā)生變化*/
$.fn.getValue = function() {
return pageDataChange;
};
})(jQuery);
您可能感興趣的文章:
- jquery監(jiān)控數(shù)據(jù)是否變化(修正版)
- jquery.autocomplete修改實現(xiàn)鍵盤上下鍵自動填充示例
- jQuery scroll事件實現(xiàn)監(jiān)控滾動條分頁示例
- 基于Jquery實現(xiàn)鍵盤按鍵監(jiān)聽
- jquery.hotkeys監(jiān)聽鍵盤按下事件keydown插件
- jquery 按鍵盤上的enter事件
- 打造個性化的功能強大的Jquery虛擬鍵盤(VirtualKeyboard)
- jQuery監(jiān)控文本框事件并作相應(yīng)處理的方法
- jQuery實現(xiàn)監(jiān)控頁面所有ajax請求的方法
- jQuery 監(jiān)控鍵盤一段時間沒輸入
相關(guān)文章
jquery validate 自定義驗證方法介紹 日期驗證
本篇文章主要是對jquery validate 自定義驗證方法 日期驗證進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02淺談struts1 & jquery form 文件異步上傳
下面小編就為大家?guī)硪黄獪\談struts1 & jquery form 文件異步上傳。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05淺談JQ中mouseover和mouseenter的區(qū)別
下面小編就為大家?guī)硪黄獪\談JQ中mouseover和mouseenter的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。2016-09-09用JQuery在網(wǎng)頁中實現(xiàn)分隔條功能的代碼
在C/S系統(tǒng)中有專門的分隔條控件,很方便實現(xiàn),但在Asp.net中卻沒有。本文介紹了一種使用JQuery技術(shù)實現(xiàn)分隔條的功能2012-08-08