gpt4 book ai didi

javascript - jQuery 鼠标事件不触发

转载 作者:行者123 更新时间:2023-11-28 13:51:07 26 4
gpt4 key购买 nike

我有一个非常奇怪的问题。我的示例代码[此处][1]工作得很好,但我的 aptana studio 编辑器中有完全相同的代码,当我在 Chrome 或 Eclipse 浏览器中尝试它时,事件不会触发。我无法想象有什么问题,因为它是完全相同的代码......

HTML

<!DOCTYPE html>
<html>
<head>
<title>OrderScreen</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script src="js/script.js" type="text/javascript"></script>
</head>
<body>
<a href="">Test</a>
</body>
</html>

jQuery

$("a").mouseup(function() {
clearTimeout(pressTimer);
// Clear timeout
return false;
}).mousedown(function() {
// Set timeout
pressTimer = window.setTimeout(function() {
alert("hcbdhaf")
}, 1000);
return false;
}).click(function() {
alert("dfsdg");
});

最佳答案

如果您的代码确实如所引用的那样,则问题是当您尝试将事件处理程序 Hook 到这些元素时,这些元素并不存在。 jsFiddle 的默认设置向您隐藏了这个问题。 (看左边,您会发现您的代码直到 load 事件触发才运行 - 这在页面加载过程中已经非常非常晚了。)

要修复它,可以:

  1. 将脚本标记移动到文档末尾,即结束 </body> 之前或之后。标签。当浏览器运行您的脚本时,元素将存在。这是recommendation of the YUI team和 Google 的网络工程师 like it too .

  2. 使用 jQuery 的 ready 事件。

结合其中任何一个,您还可以考虑使用事件委托(delegate),而不是直接在元素上连接事件。您的mouseupmousedown处理程序将附加到每个 a单独的元素。这是很多连接。如果有一个容器包含所有这些 a元素位于( body 或更好,更接近的东西)中,您可以将事件挂接到该容器上(因为这些事件冒泡),然后检查事件是否源自 a元素。 jQuery 支持事件委托(delegate),为您完成大部分艰苦的工作,通过 delegate (我喜欢它,因为它非常明确)最近,您传递给 on 的参数的六个变体之一.

关于javascript - jQuery 鼠标事件不触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10897218/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com