`

JS:停止事件冒泡和阻止浏览器的默认行为 js/jquery/prototype

    博客分类:
  • js
 
阅读更多
<
a onclick=
"toggleFriendFuncList(event, '6708062', 'he');"
></
a>

由于href是空值,如果不阻止浏览器的默认行为,产生的效果就是刷新页面。
现在我们需要做的就是阻止href的链接事件,而去执行onclick事件。
老的处理方式

<
a onclick=
"toggleFriendFuncList(event, '6708062', 'he');"
 href=
"javascript:void(0);"
></
a>

js的写法:
1)停止冒泡的写法

//如果提供了事件对象,则这是一个非IE浏览器

if
 (
 e &
amp;&
amp;
 e.stopPropagation
 )

  // 因此它支持W3C的stopPropagation()方法

  e.stopPropagation
(
)
;

else

  //否则,我们需要使用IE的方式来取消事件冒泡

  window.event
.cancelBubble
 =
 true
;

return
 false
;

2)阻止浏览器的默认行为

//如果提供了事件对象,则这是一个非IE浏览器

if
 (
 e &
amp;&
amp;
 e.preventDefault
 )

   //阻止默认浏览器动作(W3C)

  e.preventDefault
(
)
;

else

  //IE中阻止函数器默认动作的方式

  window.event
.returnValue
 =
 false
;

return
 false
;

jquery的写法:
1)return false :In event handler ,prevents default behavior and event bubbing 。
return false 在事件的处理中,可以阻止默认事件和冒泡事件。
2)event.preventDefault() :In event handler ,prevent default event (allows bubbling) 。
event.preventDefault()在事件的处理中,可以阻止默认事件但是允许冒泡事件的发生。
3)event.stopPropagation() :In event handler ,prevent bubbling (allows default behavior).
event.stopPropagation()在事件的处理中,可以阻止冒泡但是允许默认事件的发生

prototype的写法:
Event.stop(event)
用法介绍:
事件发生后,浏览器通常首先触发事件发生元素上的事件处理程序,然后是它的父元素,父元素的父元素……依此类推, 直到文档的根元素为止。这被称为 事件冒泡,是事件传播的最常见的方式。当处理好一个事件后, 你可能想要停止事件的传播,不希望它继续冒泡。
当你的程序有机会处理事件时,如果这个事件具有 默认行为,同时浏览器也会处理它。例如,点击导航链接、 将表单提交到服务器、在一个单行文本框中按下回车键等等。如果对这些事件你定义了自己的处理方式, 可能会非常希望阻止相关的默认行为。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics