当前位置:小鱼儿玄机二站 > 关于计算机 > 基于jquery的监察数据是还是不是产生转移,jQue

基于jquery的监察数据是还是不是产生转移,jQue

文章作者:关于计算机 上传时间:2019-09-03

本文实例讲述了jQuery实现监控页面所有ajax请求的方法。分享给大家供大家参考,具体如下:

这样之前的功夫又白费了。解决这些问题的办法就是:监控页面数据是否发生变化。如果发生变化,提示用户保存。如果数据未发生变化。当我们点击保存时,也不需要提交到数据库。
接下来看看解决办法:

你是不是有遇到这样的问题:页面发起两个ajax请求,希望它们都成功以后,再做一个动作?

复制代码 代码如下:

很容易想到的解决方案是,等其中一个结束以后,再发起另外一个,这个过程用回调函数来完成。

///<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 = [];

但是,如果其中一个ajax请求的代码不是你写,你改不了,怎么办?

var deafult = {
arrTags: tagName, //需监控控件的tagName属性数组
arrCtrls: ctrlIds //不监控的控件ID
};
var ops = $.extend(deafult, options);

又或者说,你只想知道某个url请求什么时候结束,不想管其他的请求,怎么弄?

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);

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
  </head>
  <body>
    <p id="test"></p>
  </body>
  <script src="js/jquery-1.11.0.min.js"></script>
  <!--首先在页面引入jquery的后面,紧接着以下代码:-->
  <script>
    //前提:所有ajax请求都是用jquery的$.ajax发起的,而非原生的XHR;
    var ajaxBack = $.ajax;
    var ajaxCount = 0;
    var allAjaxDone = function(){$('#test').append('all done!<br>');} //一行代码,就可以知道所有ajax请求什么时候结束
    //由于get/post/getJSON等,最后还是调用到ajax,因此只要改ajax函数即可
    $.ajax = function(setting){
      ajaxCount++;
      var cb = setting.complete;
      setting.complete = function(){
        if($.isFunction(cb)){cb.apply(setting.context, arguments);}
        ajaxCount--;
        if(ajaxCount==0 && $.isFunction(allAjaxDone)){
          allAjaxDone();
        }
      }
      ajaxBack(setting);
    }
  </script>
  <!--以下是别人的script-->
  <script>
    $.ajax({url: 'js/jquery-1.11.0.min.js', success: function(recv){$('#test').append('别人的ajax请求1,done<br>')}});
  </script>
  <script>
    $.get('css/main.css', null, function(recv){$('#test').append('别人的get请求,done<br>')});
  </script>
  <script>
    $.post('css/main.css', null, function(recv){$('#test').append('别人的post请求,done<br>')});
  </script>
</html>

您可能感兴趣的文章:

  • jquery监控数据是否变化(修正版)
  • jquery.autocomplete修改实现键盘上下键自动填充示例
  • jQuery scroll事件实现监控滚动条分页示例
  • 基于Jquery实现键盘按键监听
  • jquery.hotkeys监听键盘按下事件keydown插件
  • jquery 按键盘上的enter事件
  • 打造个性化的功能强大的Jquery虚拟键盘(VirtualKeyboard)
  • jQuery监控文本框事件并作相应处理的方法
  • jQuery实现监控页面所有ajax请求的方法
  • jQuery 监控键盘一段时间没输入

其他的相关函数:

$.ajax 中:

error:当出错时调用,可以用来上报错误的请求。
complete:无论成功还是失败都会调用

高版本中:

$.promise
$.when

希望本文所述对大家jQuery程序设计有所帮助。

您可能感兴趣的文章:

  • 基于jquery的监控数据是否发生改变
  • jquery监控数据是否变化(修正版)
  • jquery.autocomplete修改实现键盘上下键自动填充示例
  • jQuery scroll事件实现监控滚动条分页示例
  • 基于Jquery实现键盘按键监听
  • jquery.hotkeys监听键盘按下事件keydown插件
  • jquery 按键盘上的enter事件
  • 打造个性化的功能强大的Jquery虚拟键盘(VirtualKeyboard)
  • jQuery监控文本框事件并作相应处理的方法
  • jQuery 监控键盘一段时间没输入

本文由小鱼儿玄机二站发布于关于计算机,转载请注明出处:基于jquery的监察数据是还是不是产生转移,jQue

关键词: