Skip to main content

jQuery / Ajax - $.ajax() Passing Parameters to Callback - Good Pattern to Use?



JavaScript code I'm starting with:







function doSomething(url) {

$.ajax({ type: "GET",

url: url,

dataType: "xml",

success: rssToTarget

});

}







Pattern I would like to use:







//where elem is the target that should receive new items via DOM (appendChild)

function doSomething(url, elem) {

$.ajax({ type: "GET",

url: url,

dataType: "xml",

success: rssToTarget(elem)

});

}







I don't think I can get the callback to work this way, right? What is the proper pattern? I don't want to use global variables necessarily to temporarily hold the elem or elem name.



Source: Tips4all

Comments

  1. Like this...

    function doSomething(url, elem) {
    $.ajax({
    type: "GET",
    url: url,
    dataType: "xml",
    success: function(xml) {
    rssToTarget(xml, elem);
    }
    });
    }


    Answer to your comment: Does use of anonymous functions affect performance?

    ReplyDelete
  2. The pattern you'd like to use could work if you create a closure inside your rssToTarget function:

    function rssToTarget(element) {
    return function (xmlData) {
    // work with element and the data returned from the server
    }
    }

    function doSomething(url, elem) {
    $.ajax({ type: "GET",
    url: url,
    dataType: "xml",
    success: rssToTarget(elem)
    });
    }


    When rssToTarget(elem) is executed, the element parameter is stored in the closure, and the callback function is returned, waiting to be executed.

    ReplyDelete

Post a Comment

Popular posts from this blog

Slow Android emulator

I have a 2.67 GHz Celeron processor, 1.21 GB of RAM on a x86 Windows XP Professional machine. My understanding is that the Android emulator should start fairly quickly on such a machine, but for me it does not. I have followed all instructions in setting up the IDE, SDKs, JDKs and such and have had some success in staring the emulator quickly but is very particulary. How can I, if possible, fix this problem?