作者chrisjohn214 (咪咪奖)
看板Ajax
标题[问题] onclick eventHander移不掉
时间Thu Jan 23 17:10:25 2014
请问一下,像下面这段code,当使用者点击连结时
有办法把被点击连结的event handler移除,然後再把它加回去吗?
<html>
<head>
<link rel="stylesheet" href="css/puzzle.css" type="text/css" />
<script src="scripts/jquery.js" type="text/javascript"></script>
<script src="scripts/test.js" type="text/javascript"></script>
</head>
<body>
<div id="parent">
<a href="#" class="link1">link1</a>
<a href="#" class="link2">link2</a>
<a href="#" class="link3">link3</a>
</div>
<body>
</html>
==
$(
function() {
$("#parent").on("click", "a", function() {
linkClick(this);
});
function linkClick(link) {
$(link).off("click"); //试过这样关闭,但不成功
console.log(link);
}
}
)
换句话说,怎麽样在linkClick里把link的on click event handler关闭,
甚至在一段时间之後再把它加回来呢?
烦请大家帮忙解答,谢谢。
==
补充一下好了:
像
$("a").on("click", function() {
linkClick(this);
});
function linkClick(link) {
console.log(link);
$(link).off("click");
}
这样的话每个连结都只会在印出资料之後就关闭onclick事件,
换句话说只允许被点击一次。
然後这次的问题只是把code改成:
$("#parent").on("click", "a", function() {
linkClick(this);
});
function linkClick(link) {
console.log(link);
$(link).off("click");
}
这样就关不掉了 ~"~
於是想请问像问题中正确移除event handler的方式
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 118.170.27.64
※ 编辑: chrisjohn214 来自: 118.170.27.64 (01/23 17:14)
1F:→ lyforever:不懂你的在加回去是甚麽意思 01/23 17:20
2F:→ lyforever:但是可以用function(e){e.preventDefault()} 01/23 17:20
4F:→ lyforever:不知道是不是你要的 ... 01/23 17:26
5F:→ chrisjohn214:用e.preventDefault()跟关闭handler似乎不太一样 01/23 17:29
6F:→ chrisjohn214:楼楼上,感谢你回答,不过答案应该不是这个 ~"~ 01/23 17:36
7F:→ lyforever:我改的code不是用e.preventDefault()喔 01/23 17:39
8F:→ chrisjohn214:有,我有copy来试过了,跟我想要得结果不同 01/23 17:46
※ 编辑: chrisjohn214 来自: 118.170.27.64 (01/23 17:56)
10F:→ mrbigmouth:在哪边开的就在哪边关啊 01/23 17:47
11F:→ chrisjohn214:楼上这样会关掉全部的event handler 01/23 17:57
12F:→ chrisjohn214:link2跟link3还没被点选就也被关闭了 01/23 17:57
14F:→ lyforever:因为你绑在parent上面当然是全观 01/23 17:58
15F:→ chrisjohn214:绑在子上我知道可以 01/23 17:59
16F:→ chrisjohn214:绑在parent上就没办法挑选单一link关闭吗??? 01/23 17:59
18F:→ lyforever:因为event trigger在parent, child没有 你要关甚麽... 01/23 18:03
19F:→ lyforever:第二个selector只是filter 不是绑在它上面的意思 01/23 18:11
20F:→ lyforever:A selector string to filter the descendants of the 01/23 18:16
21F:→ lyforever:selected elements that trigger the event 01/23 18:17
23F:→ chrisjohn214:了解,这样看来只能选择全关或全开了,Thx 01/23 18:27
24F:→ lyforever:或者个别绑event 就可以个别开关 01/23 18:30
25F:→ chrisjohn214:个别绑我是清楚,不过就是想用event delegation 01/23 18:32
27F:→ chrisjohn214:楼上这个写法挺有意思的,感谢 01/23 19:41
28F:推 nightspirit:写flag去限制要不要执行click动作比较快阿 01/30 05:55