提交操作自动遮蔽实现之ajax

有时候,我们期望一些提交操作自动增加遮蔽效果,提交成功时自动去除遮蔽。

方案:

  1、 提交前增加遮蔽逻辑,成功后增加去除遮蔽逻辑,但是不够智能

  2、通过ajax拦截,实现自动添加\去除遮蔽效果

ajax拦截实现

$(document).ajaxSend(function(event,xhr,settings){
  var keys = 'add|save|submit', /* 地址关键字,自行扩展,以竖线分隔 */
    regstr = '\\S*('+key+')[A-Za-z0-9-_]*.(do|action)', /* 后缀可以自行调整 */
    urlReg = new RegExp(regstr,'gi');
    if(urlReg.test(settings.url)){ /* url满足关键字匹配 */
      settings.isSave = true; /* 标识是否提交操作 */
      $('#mainpage').addClass('loading'); /* 增加遮蔽效果 */
    }
}).ajaxComplete(function(event,xhr,settings){
  if(settings.isSave) {
    $('#mainpage').removeClass('loading');
  }
});

猜你喜欢

转载自www.cnblogs.com/xtreme/p/9431071.html