我试图使用jQuery的.click调用带有参数的函数,但我不能让它工作。
这就是我想要的工作方式:
$ (' .leadtoscore ') .click (add_event('照片'));
这电话
function add_event(event) {
blah blah blah }
如果我不使用参数,它就会工作,就像这样:
$('.leadtoscore').click(add_event);
function add_event() {
blah blah blah }
但是我需要能够将参数传递给add_event函数。
我该怎么做这件事呢?
我知道我可以使用.click(function() {blah},但我从多个地方调用add_event函数,并想这样做。
你需要像这样使用一个匿名函数:
$('.leadtoscore').click(function() {
add_event('shot')
});
你可以像在例子中那样调用它,只是一个没有参数的函数名,就像这样:
$('.leadtoscore').click(add_event);
但是add_event方法不会像它的参数一样得到'shot',而是任何传递给它的回调的点击,这是事件对象本身…所以在这种情况下不适用,但在其他情况下适用。如果需要传递参数,请使用匿名函数…或者,还有另一个选项,使用.bind()并传递数据,就像这样:
$('.leadtoscore').bind('click', { param: 'shot' }, add_event);
并在add_event中访问它,像这样:
function add_event(event) {
//event.data.param == "shot", use as needed
}
我成功地像这样使用.on():
$('.leadtoscore').on('click', {event_type: 'shot'}, add_event);
然后在add_event函数中,你可以像这样访问'shot':
event.data.event_type
有关更多信息,请参阅.on()文档,其中提供了以下示例:
function myHandler( event ) {
alert( event.data.foo );
}
$( "p" ).on( "click", { foo: "bar" }, myHandler );
为了彻底起见,我遇到了另一个解决方案,它是jQuery点击事件处理程序1.4.3版本中引入的功能的一部分。
它允许您将数据映射传递给事件对象,该对象将自动作为第一个参数由jQuery反馈给事件处理程序函数。数据映射将作为第一个参数传递给.click()函数,然后是事件处理程序函数。
下面是一些代码来说明我的意思:
// say your selector and click handler looks something like this...
$("some selector").click({param1: "Hello", param2: "World"}, cool_function);
// in your function, just grab the event object and go crazy...
function cool_function(event){
alert(event.data.param1);
alert(event.data.param2);
}