加个标记达到同步效果~

————————————————————————————————————————————————————————————————————————————

修改前:

function save() {
                var jsonarray=[];
    var jsonText;
$("table tr").each(function(i){
if(i!=0){
   var widgetId;
   var isChecked;
   var column;
   var row;
   var check = document.getElementsByName("check");
       if(check[i-1].checked == true){
        isChecked = true;
       }else{
        isChecked = false;
       }
   
       widgetId=check[i-1].value;
   
   $(this).children("td").each(function(j){
       if(j==2){
        column=$(this).text();
       }else if(j==3){
        row=$(this).text();
       }
       
   });
   
       var obj={
"widgetId":widgetId,
"isChecked":isChecked,
"column":column,
"row":row
           };
       jsonarray.push(obj);
   var jsonList = eval(jsonarray); 
   jsonText = JSON.stringify(jsonList);
}
});

   $.ajax({
type: 'POST',
url: "${ctx }/erp/widgetUserConfig.action?method:saveDesktopSet",
dataType: 'json',
data: {
jsonarray:jsonText
},
success : function(data) {
var json = eval(data);
var flag = json.flag;
if(flag == "true"){
alert("保存成功!");
}}
});

}
}


问题:连续点击按钮会导致数据的重复保存!


————————————————————————————————————————————————————————————————————————————

给ajax加个同步,使得未保存完情况下不能发送第二次保存的执行,但是ajax同步处理会卡顿,在马老师的指导下加了个标记

修改后:

function save() {
var saveFlag=false; //标记保存与否
    var jsonarray=[];
    var jsonText;
if(!saveFlag){                         //未保存则。。;已保存则停下来
$("table tr").each(function(i){
if(i!=0){
   var widgetId;
   var isChecked;
   var column;
   var row;
   var check = document.getElementsByName("check");
       if(check[i-1].checked == true){
        isChecked = true;
       }else{
        isChecked = false;
       }
   
       widgetId=check[i-1].value;
   
   $(this).children("td").each(function(j){
       if(j==2){
        column=$(this).text();
       }else if(j==3){
        row=$(this).text();
       }
       
   });
   
       var obj={
"widgetId":widgetId,
"isChecked":isChecked,
"column":column,
"row":row
           };
       jsonarray.push(obj);
   var jsonList = eval(jsonarray); 
   jsonText = JSON.stringify(jsonList);
}
});

   $.ajax({
type: 'POST',
url: "${ctx }/erp/widgetUserConfig.action?method:saveDesktopSet",
dataType: 'json',
data: {
jsonarray:jsonText
},
success : function(data) {
var json = eval(data);
var flag = json.flag;
if(flag == "true"){
alert("保存成功!");
saveFlag=true;                      //已保存
}}
});

}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值