Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Replacing anonymous functions with named function (in jQuery)

My original (working) code looks like:

jQuery().ready(function ($) {
    $('[id="errorMessages"]').ajaxStart(function () {
        $(this).html("");
    });
    $('[id="errorMessages"]').ajaxError(function (e, jqxhr, settings, exception) {
        //...
    });
});

When I am trying to replace the anonymous functions into a named function calls like: (I am doing a POC for some requirement, which expects such implementation.)

function fs() {
        $(this).html("");
}
function fe(e, jqxhr, settings, exception) {
        //...
}
jQuery().ready(function ($) {
    $('[id="errorMessages"]').ajaxStart(fs());
    $('[id="errorMessages"]').ajaxError(fe(e, jqxhr, settings, exception));
});

I am getting an error stating the parameter 'e' is undefined. But the functions without parameters seems working fine.

I am wondering how the anonymous functions could receive the parameters, while the same not available when calling an external function.

Is there a way to convert these parameterized anonymous functions into regular function calls.

like image 652
Krishna Sarma Avatar asked May 31 '26 12:05

Krishna Sarma


1 Answers

You are assigning the functions to the handlers incorrectly, try this:

jQuery().ready(function ($) {
    $('[id="errorMessages"]').ajaxStart(fs);
    $('[id="errorMessages"]').ajaxError(fe);
});

Note that passing the name of the function without brackets means you are giving the reference of that function which should be used when the event occurs.

Your current code will call the function when the event is attached (hence why you're getting 'e' is undefined) and assign the result of the function to the event handler.

like image 66
Rory McCrossan Avatar answered Jun 02 '26 02:06

Rory McCrossan