我正在尝试使用jQuery的.click调用带参数的函数,但我无法让它工作。
这就是我希望它发挥作用的方式:
$('.leadtoscore').click(add_event('shot'));
调用
function add_event(event) {
blah blah blah }
如果我不使用参数,它可以工作:
$('.leadtoscore').click(add_event);
function add_event() {
blah blah blah }
但我需要能够将参数传递给我的add_event
函数。
我该怎么做这个特定的事情?
我知道我可以使用.click(function() { blah }
,但我会从多个地方调用add_event
函数,并希望这样做。
答案 0 :(得分:479)
为了彻底,我遇到了另一个解决方案,它是jQuery click event handler.
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);
}
我知道这个问题在游戏中已经很晚了,但之前的答案让我得到了这个解决方案,所以我希望它能在某个时候帮到某个人!
答案 1 :(得分:77)
你需要使用这样的匿名函数:
$('.leadtoscore').click(function() {
add_event('shot')
});
您可以像示例中那样调用它,只需要一个没有参数的函数名,如下所示:
$('.leadtoscore').click(add_event);
但add_event
方法不会将'shot'
作为参数,而是click
传递给它的回调,即event
对象本身......所以它不适用在这种情况下,但适用于许多其他人。如果您需要传递参数,请使用匿名函数...或者,有一个其他选项,使用.bind()
并传递数据,如下所示:
$('.leadtoscore').bind('click', { param: 'shot' }, add_event);
并在add_event
中访问它,如下所示:
function add_event(event) {
//event.data.param == "shot", use as needed
}
答案 2 :(得分:34)
如果你按照它的方式打电话......
$('.leadtoscore').click(add_event('shot'));
...你需要让add_event()
返回一个函数,比如......
function add_event(param) {
return function() {
// your code that does something with param
alert( param );
};
}
返回该函数并将其用作.click()
的参数。
答案 3 :(得分:23)
我成功使用.on()就像这样:
$('.leadtoscore').on('click', {event_type: 'shot'}, add_event);
然后在add_event
功能中,您可以访问“拍摄”照片。像这样:
event.data.event_type
有关详细信息,请参阅.on() documentation,其中提供了以下示例:
function myHandler( event ) {
alert( event.data.foo );
}
$( "p" ).on( "click", { foo: "bar" }, myHandler );
答案 4 :(得分:9)
是的,这是一篇旧帖子。无论如何,有人可能会发现它很有用。这是将参数发送到事件处理程序的另一种方法。
//click handler
function add_event(event, paramA, paramB)
{
//do something with your parameters
alert(paramA ? 'paramA:' + paramA : '' + paramB ? ' paramB:' + paramB : '');
}
//bind handler to click event
$('.leadtoscore').click(add_event);
...
//once you've processed some data and know your parameters, trigger a click event.
//In this case, we will send 'myfirst' and 'mysecond' as parameters
$('.leadtoscore').trigger('click', {'myfirst', 'mysecond'});
//or use variables
var a = 'first',
b = 'second';
$('.leadtoscore').trigger('click', {a, b});
$('.leadtoscore').trigger('click', {a});
答案 5 :(得分:5)
$imgReload.data('self', $self);
$imgReload.click(function (e) {
var $p = $(this).data('self');
$p._reloadTable();
});
将javaScript对象设置为onclick元素:
$imgReload.data('self', $self);
从“this”元素中获取Object:
var $p = $(this).data('self');
答案 6 :(得分:2)
我得到了简单的解决方案:
<button id="btn1" onclick="sendData(20)">ClickMe</button>
<script>
var id; // global variable
function sendData(valueId){
id = valueId;
}
$("#btn1").click(function(){
alert(id);
});
</script>
我的意思是将值onclick
事件传递到javascript function sendData()
,初始化为变量,然后通过jquery事件处理程序方法获取它。
这是可能的,因为首先调用sendData(valueid)
并初始化该值。然后在执行jquery事件后执行并使用该值。
这是直接的解决方案,有关详细信息的解决方案,请转到Here。
答案 7 :(得分:0)
因为没有人指出(令人惊讶)。您的问题是,$('.leadtoscore').click(add_event);
与 $('.leadtoscore').click(add_event('shot'));
不同。第一个传递一个函数,第二个传递一个函数调用,因此该函数的结果被传递给 .click()
。那不是你想要的。这是您想要的普通 JavaScript 术语:
$('.leadtoscore').click(add_event.bind(this, 'shot'));
Function.prototype.bind()
将函数传递给 .click()
,就像在第一个示例中一样,但绑定了 this
和可在调用时访问的参数。