event.preventDefault() 与返回 false
技术问答
206 人阅读
|
0 人回复
|
2023-09-12
|
当我想在事件被触发后阻止其他事件处理程序时,我可以使用两种技术之一。我将在示例中使用 jQuery,但也适用于纯 JS:* ^4 s- H* t" z# a
1. event.preventDefault()$('a').click(function (e) / custom handling here e.preventDefault();code]2. return false[code]$('a').click(function ()()()()())()()()()()()()())()())())())())()())())()())()())()()()))())()())())())())())())()))())())())())())())())())()())()())()())())()())())()())())())())())()())())())()())())())())()()())()())()())()())()()()()()()()()())())())()))())())()))())())()())()))()))())())())()))()()()()()))()))()))()())()())()))()))()()())()))())))()))()))()))()))()()()))()()()())()))())())))()()()())()()))))())))))))()))))()))())))())))()())())())()))())()()()()()))())))))())))()()()()()())))))()))))))()()))))())()))))()())())())()()()()())())())()))()))))()))))())))())))()))))())))())))()()()()()()())())))custom handling here return false;});
. Y% J" k7 l) D ^ 这两种停止事件传播的方法有什么显著区别吗?0 `. `: Y o' w9 g ~
对我来说,return false;它比执行方法更简单、更短、更不容易出错。使用此方法时,您必须记住正确的大小写、括号等。
! J6 k, z, s% p' H此外,在调用该方法之前,我必须在回调中定义第一个参数。也许有一些原因,我应该避免这样做并改用它preventDefault?更好的方法是什么?4 K: _$ G7 B! F8 o
- |/ R" V) x+ ]- ]( m& ?% I" m
解决方案:
1 X) W4 z( F* ?6 R' a return false从jQuery 事件处理程序e.preventDefault中调和调用e.stopPropagation传递的jQuery.Event 对象实际上是相同的 。. ~ s. N, ~8 O
e.preventDefault()预防默认事件,e.stopPropagation()防止事件冒泡,return false两者兼而有之。请注意这种行为和普通(非 jQuery)事件处理程序不同,值得注意的是,return false不会阻止事件冒泡。 |
|
|
|
|
|