他们俩实现的功能都一样,都是阻止默认的点击事件,那么为什么建议用 preventDefault
代替呢?
// 旧版写法
$('a').click(function () {
return false;
});
// 新版写法
$('a').click(function (e) {
e.preventDefault();
});
他们俩实现的功能都一样,都是阻止默认的点击事件,那么为什么建议用 preventDefault
代替呢?
// 旧版写法
$('a').click(function () {
return false;
});
// 新版写法
$('a').click(function (e) {
e.preventDefault();
});
return false 等同于
e.preventDefault();
e.stopPropagation();
的组合。
想更清楚的了解区别,看看这个在线调试:http://www.gbtags.com/gb/debug/de1361ab-0605-4c6d-a21b-8c082e3bd251.htm
13 回答13.1k 阅读
7 回答2.3k 阅读
3 回答1.4k 阅读✓ 已解决
6 回答1.5k 阅读✓ 已解决
2 回答1.5k 阅读✓ 已解决
3 回答1.5k 阅读✓ 已解决
2 回答1.2k 阅读✓ 已解决
通常,
event.preventDefault()
都会放在event handler的第一行。这样的话, 假设在event handler中有一个JavaScript error,
那么, 放在first line的
event.preventDefault()
就可以阻止submit行为, console还可以report这个error.而,
return false
是放在event handler的最后一行的。并且, 他是相当于
event.preventDefault()
和event.stopPropagation()
, 如果我们想阻止bubbling的话, 就可以用return false
.更重要的是,
return false
只能用于DOM Level 0 Event handler,在DOM Level 2 Event Handler是没用的, demo.而,
event.preventDefault()
2者都兼容。综上, 当然是推荐用
event.preventDefault()
啦。