在浏览器中经常会遇到的两个麻烦,下面提供两个函数解决方式做参考,并提供一个demo让你更直观地了解我所说的这两个麻烦。

  1. <script language="javascript">
  2.  
  3. /*---------------------------
  4.     功能:停止事件冒泡
  5.     ---------------------------*/
  6.     function stopBubble(e) {
  7.     //如果提供了事件对象,则这是一个非IE浏览器
  8.     if ( e && e.stopPropagation )
  9.     //因此它支持W3C的stopPropagation()方法
  10.     e.stopPropagation();
  11.     else
  12.     //否则,我们需要使用IE的方式来取消事件冒泡
  13.     window.event.cancelBubble = true;
  14.     }
  15.     //阻止浏览器的默认行为
  16.     function stopDefault( e ) {
  17.     //阻止默认浏览器动作(W3C)
  18.     if ( e && e.preventDefault )
  19.     e.preventDefault();
  20.     //IE中阻止函数器默认动作的方式
  21.     else
  22.     window.event.returnValue = false;
  23.     return false;
  24.     }
  25.  
  26. </script>

相关文章: