+1  A: 

The function signature would simply be:

 function newConfirm(msg, okAction, cancelAction);

and would be used as:

 function newConfirm(msg, okAction, cancelAction){
   var ok = doWhateverPromptIsNecessary();
   if (ok) {
     okAction();
   } else {
     cancelAction();
   }
 }

That is, to pass function "pointers" in to a function as arguments, simply pass in the function name without the (). The function signature is the same.

Graza
yes you are correct but i am looking for some magical pattern which can do that inside the function body. Which only can help me override the window.confirm = confirm(str) dialog. Only problem with above is that i have to change calls for all the confim which are used already in code.
Anil Namde
Unfortunately that is not possible, as others have indicated.
Graza
+2  A: 

All 3 methods actually stop js execution, not just the confirm, because they're all modal dialogs. Personally, I would try to keep everything as asynchronous as possible as modal dialogs prevent interaction with the current document.

Your best bet is to use callback functions from the new confirm popup as you suggested yourself.

I'm having a hard time understanding exactly what you want to achieve. It sounds like you want to do something like the following:

  • Run some javascript code
  • Display a "confirm" box
  • Wait until the ok button or cancel button is clicked
  • Continue code when user clicks ok, return when user clicks cancel.

The reason you want to do this is that overriding the function with something that makes use of callbacks would require rewriting each section of code that uses the confirm function. If you want my advice, I would go ahead and rewrite the code so that it performs asynchronously. There's no way you can delay script execution without locking up the document which includes the OK and Cancel actions of your dialog.

Andy E
+2  A: 

if you changed the roles Alert / Prompt / Confirm. slows the execution pending user interaction to run the following code.

Overriding these functions, the code continues its execution.

To achieve this you have to modify each part of the code and work as if you were with asynchronous functions.

Then you can use any plugin for windows as sexy-alert-box, and overwrite Alert / Prompt / Confirm

andres descalzo
+2  A: 

Now this is problem that this cant help me change the confirm dialog across the site as we did with alert();

That's correct. It's not possible to reproduce the synchronous nature of the alert/confirm/prompt functions in native JavaScript. There is the non-standard method showModalDialog which can do it using a separate pop-up document, but it's not supported by all browsers and it's generally considered highly undesirable.

So the plug-in-replacement strategy isn't going to work. You are going to have to change every place you called these methods in the rest of the script.

The usual pattern is to do it using inline anonymous functions, to preserve the local variables using a closure, eg. replace:

function buttonclick() {
    var id= this.id;
    if (confirm('Are you sure you want to frob '+id+'?'))
        frob(id);
    wipe(id);
}

with:

function buttonclick() {
    var id= this.id;
    myConfirm('Are you sure you want to frob '+id+'?', function(confirmed) {
        if (confirmed)
            frob(id);
        wipe(id);
    });
}

If you need this to be preserved you would need to look at a further nested closure or function.bind to do it. If you have your call to confirm in a loop things get considerably more difficult.

Obviously you also have to ensure that critical global state doesn't change whilst the confirm box is up. Usually this risk is minimised by greying out the rest of the page with an overlay to stop clicks getting through. However if you have timeouts they can still fire.

bobince
+1, I think part of bringing old sites like this up to date is removing the synchronous nature of modal boxes and getting as much of it as you can working asynchronously. Nobody appreciates modal popups on web pages.
Andy E