13

Using jQuery, I set a link tag's click handler like this:

$('#lnk').click(handleClick);

handleClick does something like this:

function handleClick() {
    var $this = $(this);
    ...
}

Now I have a need to directly call handleClick() outside of #lnk being clicked. Is there a way for me to set this when calling handleClick?

August Lilleaas
  • 54,010
  • 13
  • 102
  • 111
slolife
  • 19,520
  • 20
  • 78
  • 121

3 Answers3

26

You can use apply() or call():

handleClick.call(theElementThatShouldBeThis);

But of course theElementThatShouldBeThis must be a DOM element or something that is accepted as input for jQuery().

And it becomes more tricky if you are accessing the event element inside handleClick. But I will just assume you don't ;)

You can also always execute the event handler in the context of #lnk by calling $('#lnk').click() (which simulates a click).

Felix Kling
  • 795,719
  • 175
  • 1,089
  • 1,143
5

I think you're looking for "call" or "apply":

Call

https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Function/call

Apply

https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Function/apply

From MDC

var result = fun.apply(thisArg, [argsArray]);

or

var result = fun.call(thisArg[, arg1[, arg2[, ...]]]); 
Community
  • 1
  • 1
Karim
  • 18,347
  • 13
  • 61
  • 70
0

Use Function.apply and pass in the DOM element returned by the query.

handleClick.apply($('#lnk')[0]);

Or better yet, let jQuery simulate a click on the element (Assuming you've already attached the click event handler).

$('#lnk').click();
Roy Tinker
  • 10,044
  • 4
  • 41
  • 58