ChatGPT解决这个技术问题 Extra ChatGPT

jQuery 的 .click - 将参数传递给用户函数

我正在尝试使用 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 函数并希望这样做。

这是从 patricks 答案中采用的,我认为这是一个很好的解决方案:jsfiddle.net/naRRk/1

M
Muhammad Dyas Yaskur

为了彻底起见,我遇到了另一个解决方案,它是 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);
}

对我来说,我必须删除数据部分,例如 alert(event.param1);我正在使用 jquery 1.10.2,也许他们改变了一些东西?
我在服务器端动态创建对象并将点击事件绑定: r.OnClientClick = "imageClicked({param1: '" + obj.Command + "' });return false";然后在客户端我有: function imageClicked(event) { if (event.param1 == "GOTO PREVIOUS") {... 如果我使用 event.data.param1 它说它是未定义的。现在我在这里输入了它,我可以看到不同之处,d'oh!
@Family - 哈哈没问题,很高兴能提供帮助,即使是通过评论;)
@totymedli - 我想你总是可以在其他地方调用它,传递一个相同结构的对象: var param_obj = {data : {param1: "Hello", param2: "World"}}; cool_function(param_obj);
这比使用 HTML5 数据属性要好得多,谢谢! (并且解决了 JSHint 抱怨在回调中使用 'this' 的问题!)
N
Nick Craver

您需要使用这样的匿名函数:

$('.leadtoscore').click(function() {
  add_event('shot')
});

您可以像在示例中那样调用它,只是一个不带参数的函数名,如下所示:

$('.leadtoscore').click(add_event);

但是 add_event 方法不会得到 'shot' 作为它的参数,而是任何 click 传递给它的回调,即 event 对象本身......所以它不适用 在这种情况下< /em>,但适用于许多其他人。如果您需要传递参数,请使用匿名函数...或者,有一个 other 选项,使用 .bind() 并传递数据,如下所示:

$('.leadtoscore').bind('click', { param: 'shot' }, add_event);

并在 add_event 中访问它,如下所示:

function add_event(event) {
  //event.data.param == "shot", use as needed
}

当你说公正时,这是否意味着只有?其次,这是否意味着我可以在我的 add_event 函数中使用 $(this) ,就像我通常在匿名函数中一样?
@phoffer - 是的,“只是”意味着没有参数,只有函数名,它是对函数的引用,而不是运行要分配给 click 处理程序的函数的结果。在上面的匿名方法和 .bind() 示例中,您可以使用 this,它将引用您点击的 .loadtoscore(如您所料)。在最后一个示例中,在 add_event(event) 内部也是如此,使用 this$(this) 会是您想要的。
@phoffer:您必须显式传递元素才能使用它,例如:function(){ add_event('shot', $(this));}function add_event(event, element){...}element 在这里是一个 jQuery 元素(它与 bind() 一起使用,尽管正如 Nick 提到的那样)。
@Felix - 他还可以在函数内部使用 $(this),例如:jsfiddle.net/tSu5t
u
user113716

如果你按照你的方式称呼它......

$('.leadtoscore').click(add_event('shot'));

...您需要让 add_event() 返回一个函数,例如...

function add_event(param) {
    return function() {
                // your code that does something with param
                alert( param );
           };
}

该函数被返回并用作 .click() 的参数。


@jAndy - 感谢您发布包含 event 参数的示例。我应该把它包括在内。 :o)
G
Gravity Grave

我使用 .on() 成功了,如下所示:

$('.leadtoscore').on('click', {event_type: 'shot'}, add_event);

然后在 add_event 函数中,您可以像这样访问“shot”:

event.data.event_type

有关详细信息,请参阅 .on() documentation,其中提供了以下示例:

function myHandler( event ) {
  alert( event.data.foo );
}
$( "p" ).on( "click", { foo: "bar" }, myHandler );

K
Kevin

是的,这是一个旧帖子。无论如何,有人可能会觉得它很有用。这是向事件处理程序发送参数的另一种方法。

//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});

V
Vladimir Novick
      $imgReload.data('self', $self);
            $imgReload.click(function (e) {
                var $p = $(this).data('self');
                $p._reloadTable();
            });

将 javaScript 对象设置为 onclick 元素:

 $imgReload.data('self', $self);

从“this”元素获取对象:

 var $p = $(this).data('self');

惊人的!可悲的是,这是我尝试使用 jquery 变量时唯一有效的方法!不知道为什么。 :|
s
susan097

我得到了简单的解决方案:

 <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


我在这里看不到传递动态参数的方法,只有硬编码的值。
这样你只传递 valueId 并丢失元素和事件对象。
s
shaedrich

由于没有人指出(令人惊讶)。您的问题是,$('.leadtoscore').click(add_event);$('.leadtoscore').click(add_event('shot')); 不同。第一个传递一个函数,第二个传递一个函数调用,因此该函数的结果被传递给 .click()。那不是你想要的。这是你想要的原生 JavaScript 术语:

$('.leadtoscore').click(add_event.bind(this, 'shot'));

Function.prototype.bind() 将函数传递给 .click(),就像在第一个示例中一样,但绑定了 this 和在调用时可访问的参数。