基于jquery的監(jiān)控數據是否發(fā)生改變
更新時間:2011年04月11日 20:46:54 作者:
在實際開發(fā)中經常會遇到數據沒發(fā)生改變是,由于用戶不小心點擊保存,這樣導致數據庫的日志增大;還有數據填寫好后,忘了添加保存直接關閉頁面離開。
這樣之前的功夫又白費了。解決這些問題的辦法就是:監(jiān)控頁面數據是否發(fā)生變化。如果發(fā)生變化,提示用戶保存。如果數據未發(fā)生變化。當我們點擊保存時,也不需要提交到數據庫。
接下來看看解決辦法:
///<reference path="jquery-1.3.2-vsdoc2.js" />
(function($) {
var pageDataChange = false //默認標識頁面數據未發(fā)生改變
/*監(jiān)控頁面數據是否發(fā)生變化*/
$.fn.MonitorDataChange = function(options) {
var tagName = new Array('Input', 'Select', 'Textarea');
var ctrlIds = [];
var deafult = {
arrTags: tagName, //需監(jiān)控控件的tagName屬性數組
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;
};
/*返回頁面數據是否發(fā)生變化*/
$.fn.getValue = function() {
return pageDataChange;
};
})(jQuery);
接下來看看解決辦法:
復制代碼 代碼如下:
///<reference path="jquery-1.3.2-vsdoc2.js" />
(function($) {
var pageDataChange = false //默認標識頁面數據未發(fā)生改變
/*監(jiān)控頁面數據是否發(fā)生變化*/
$.fn.MonitorDataChange = function(options) {
var tagName = new Array('Input', 'Select', 'Textarea');
var ctrlIds = [];
var deafult = {
arrTags: tagName, //需監(jiān)控控件的tagName屬性數組
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;
};
/*返回頁面數據是否發(fā)生變化*/
$.fn.getValue = function() {
return pageDataChange;
};
})(jQuery);
相關文章
jquery validate 自定義驗證方法介紹 日期驗證
本篇文章主要是對jquery validate 自定義驗證方法 日期驗證進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02淺談struts1 & jquery form 文件異步上傳
下面小編就為大家?guī)硪黄獪\談struts1 & jquery form 文件異步上傳。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05淺談JQ中mouseover和mouseenter的區(qū)別
下面小編就為大家?guī)硪黄獪\談JQ中mouseover和mouseenter的區(qū)別。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。2016-09-09