這樣之前的功夫又白費了。解決這些問題的辦法就是:監控頁面資料是否發生變化。如果發生變化,提示使用者儲存。如果資料未發生變化。當我們點擊儲存時,也不需要提交到資料庫。
接下來看看解決辦法:
複製代碼 代碼如下:
///<reference path="jquery-1.3.2-vsdoc2.js" />
(function($) {
var pageDataChange = false //預設標識頁面資料未發生改變
/*監控頁面資料是否發生變化*/
$.fn.MonitorDataChange = function(options) {
var tagName = new Array('Input', 'Select', 'Textarea');
var ctrlIds = [];
var deafult = {
arrTags: tagName, //需監控控制項的tagName屬性數組
arrCtrls: ctrlIds //不監控的控制項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;
};
/*返回頁面資料是否發生變化*/
$.fn.getValue = function() {
return pageDataChange;
};
})(jQuery);