Javascript 在传递参数时立即执行函数,这是不希望的

当我运行代码时:

 $(".pro-tip-1").mouseover(activateProTip(1));

它立即调用函数 activateProTip。它不会等待鼠标悬停成为真实场景。

现在,如果我取出传递的参数 (1),它就会按预期运行。它等待鼠标悬停为真,然后调用该函数。这就是我想要的,但我也想通过一个论点。

 $(".pro-tip-1").mouseover(activateProTip);

问题是我似乎无法传递一个参数并让它按预期运行,但我希望能够传递一个参数。

我对 Javascript 完全陌生,如果这还不是很明显,所以请让您的响应代码保持简单易懂,提前致谢!


繁星点点滴滴
浏览 116回答 2
2回答

冉冉说

这是预期的,所需的参数是一个函数。如果您传递一个语句,它将立即被解释(您可能调用了一个实际上返回您想要在鼠标悬停时调用的函数的函数!)。您可以编写一个函数,然后activateProTip使用参数进行调用。$(".pro-tip-1").mouseover(() => activateProTip(1));

LEATH

尝试这个解决方案,它会起作用$(".pro-tip-1").mouseover(()=>activateProTip(1));说明:您可以对点击事件使用always回调函数。当你像这样调用(activateProTip(1))时,这不会绑定事件,这就是为什么它会立即调用
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript