ajax异步提交 有时会出现无bug的数据处理异常-----debug没有问题,正常运行却数据处理不正确,极少机会会出现正常的处理结果

ajax  被使用时,常默认的就使用了异步处理。

当遇到后面的代码对同样的数据进行处理 或 要依赖前面ajax处理的结果时,就会导致数据处理结果不正确,未达到预期值。

且,debug时却能正常完成功能,得到预期值。再就是多次测试,又有很少的机会会出现正确数据结果。

 

这就是ajax异步和同步的问题,

debug时 程序一直处于同步的过程中执行代码。所以设置的异步被无效化,看不到数据处理的异样。

不debug时,就会出现数据处理的顺序不对,导致结果不对。

解决方法就是将ajax的属性async  改为 false  即:同步

 

//jquery的async:false,这个属性 
//默认是true:异步,false:同步。

function submit_adjust(){
            $.ajax({
                  type: "post",
                  url: basePath + "/provinceKpi/submitAdjust.do",
                  contentType: "application/json; charset=utf-8",
                  data:JSON.stringify($('#form_dialog').serializeObject()),
                  dataType: 'JSON',
                  async: false,
                  success: function (data) {
                      alert("调整成功,并记录!");
                  },
                  error: function () {
                      alert('调整数据提交失败');
                  },
                  complete: function () {

                  }
              });
        }
//调整按钮的点击事件
function adjustment(){
     BootstrapDialog.show({
         title: 'kpi数据调整',
         size :BootstrapDialog.SIZE_WIDE,
         message: $('<div></div>').load(basePath + '/provinceKpi/dialog/adjust_dialog.do',{limit: 25}, 
        function(data){
         }),
         buttons: [
                   {
                       label: '确认调整',
                       action: function(dialog) {
                           if(confirm("确认调整?")){
                               submit_adjust();
                               dialog.close();
                               $("#grid").bootstrapTable('refresh');
                           }
                       }
                   }
                   ,{
                       label: '关闭',
                       action: function(dialog) {
                           dialog.close();
                       }
                   }]
     });
}

//上面代码是我在开发中遇到的   
/*先调用submit_adjust()方法,然后 接着又刷新了列表,这两个方法处理的是同一个表的数据,如果ajax采用了默认的异步就会出现数据处理错误的现象*/

 

posted @ 2019-01-04 18:14  做你的猫  阅读(551)  评论(0编辑  收藏  举报