Overriding Javascript Confirm() while preserving the callback

后端 未结 1 1155
礼貌的吻别
礼貌的吻别 2021-01-02 16:14


To the point, I want to override the standard js confirm() function within a jQuery plugin. I have figured out how to do it with the simple function layout

相关标签:
1条回答
  • 2021-01-02 17:17

    This is possible but not exactly as you describe. The typical way the confirm function is used is:

    if(confirm("Are you sure you want to submit this form?")) {
        form.submit();
    }
    

    In the above example, the button press is returned synchronously to the script. Execution is paused within the function until a button is pressed.

    A "modal dialog" is just an overlay over the entire contents of an HTML web page. To the browser, buttons within such an overlay work the same way as buttons anywhere else within that page do.

    Since JavaScript handles such button clicks asynchronously (i.e. using callback functions to handle events) rather than synchronously, the approach you are attempting will not work.

    You would need to change all parts of the code that use the confirm function to look like this:

    confirm("Are you sure you want to submit this form?", function(result) {
        if(result) {
            form.submit();
        }
    });
    

    This would work just as registering an event handler with jQuery itself does. Script execution continues immediately, skipping past all the code in the anonymous function. Later, the browser will call that function indirectly through a JavaScript event handler that you register within the confirm function, its purpose to call the callback function with either true or false as appropriate.

    0 讨论(0)
提交回复
热议问题