Search code examples
javascriptfunction-expression

How to use the same callback function more than once?


I'm a programming newbie, and I can't figure out how to store a function in JQuery and run in it multiple places.

I have:

$(function () {
  $("div.class").click(function(){
    //Doo something

  });

  $("div.secondclass").click(function(){
    //Doo something
  });

});

Now the 2 "//Doo somethings" are the same, and I don't want to write the same code again.

If I put:

$(function () {

  function doosomething ()
  {
    //Doo something
  }

  $("div.class").click(doosomething);

  $("div.secondclass").click(doosomething);

});

That would run the function on page load, rather than only when it clicks.

How do I do this correctly?

Thanks!


Solution

  • The following should work nicely.

    $(function() {
    
      // Way 1
      function doosomething()
      {
        //Doo something
      }
    
      // Way 2, equivalent to Way 1
      var doosomething = function() {
        // Doo something
      }
    
      $("div.class").click(doosomething);
    
      $("div.secondclass").click(doosomething);
    
    });
    

    Basically, you are declaring your function in the same scope as your are using it (JavaScript uses Closures to determine scope).

    Now, since functions in JavaScript behave like any other object, you can simply assign doosomething as the function to call on click by using .click(doosomething);

    Your function will not execute until you call it using doosomething() (doosomething without the () refers to the function but doesn't call it) or another function calls in (in this case, the click handler).