George_Fal 2015-01-25 16:43 采纳率: 0%
浏览 10

在确认时调用$ ajax

how can i prevent/invoke $ajax by pressing Cancel or Ok button by calling myConfirm function ? currently i get undefined if i try with:

 var vCal = myConfirm('dialogText', 'dialogTitle');

do i missed something ?

function myConfirm(dialogText, dialogTitle) {
$('<div style="padding: 10px; max-width: 500px; word-wrap: break-word;">' + dialogText + '</div>').dialog({
    .....
    buttons: {
      "OK" : function (e) {
        console.log('yes');
        $(this).dialog('destroy');
        return true;
      },
      "Abbrechen" : function (e) {
        console.log('no');
        $(this).dialog('destroy');
        return false;
      }
    }
});
}   

function openTickerDialogDelete (id) {
....

if(!myConfirm('dialogText', 'dialogTitle')) {
    return false;
} 
console.log('call ajax');
$.ajax({    
    .....
        success: function( data ) {

        }
})
}

using return confirm() works great, but i would like to use the dialog box

thank you

  • 写回答

1条回答 默认 最新

  • weixin_33674437 2015-01-25 16:54
    关注

    Simply place the ajax call inside the OK button function it will execute when the button is clicked:

    function myConfirm(dialogText, dialogTitle, okCallback) {
    $('<div style="padding: 10px; max-width: 500px; word-wrap: break-word;">' + dialogText + '</div>').dialog({
        .....
        buttons: {
          "OK" : function (e) {
            if ($.isFunction(okCallback)) {
               okCallback();
            }
            $(this).dialog('destroy');
            return true;
          },
          "Abbrechen" : function (e) {
            console.log('no');
            $(this).dialog('destroy');
            return false;
          }
        }
    });
    }
    

    Open dialog with any success function:

    myConfirm('dialogText', 'dialogTitle', function(){
        $.ajax({    
            .....
            success: function( data ) {
    
            }
        });
    });
    

    Open a dialog without a success function

    myConfirm('dialogText', 'dialogTitle');
    

    Calling a function with parameters:

    myConfirm('dialogText', 'dialogTitle', function(){
        tickerDelete(id);
    });
    
    评论

报告相同问题?