js中的冒泡事件与事件监听

以下文章转至http://www.51obj.cn/?p=336

冒泡事件

js中“冒泡事件”并不是能实际使用的花哨技巧,它是一种对js事件执行顺序的机制,“冒泡算法”在编程里是一个经典问题,冒泡算法里面的冒泡应该 说是交换更加准确;js里面的“冒泡事件”才是真正意义上的“冒泡”,它从DOM最低层逐层遍历树,然后附加相应事件。以下面代码为例:

<title>冒泡事件</title>
<script type="text/javascript">
function Add(sText)
{
    document.getElementById("Console").innerHTML +=sText;
}
</script>
</head>

<body οnclick="Add(’body事件触发<br />’)">
<div οnclick="Add(’div事件触发<br />’)">
    <p οnclick="Add(’p事件触发<br />’)" style="background:#c00;">点击</p>
</div>
<div id="Console" style="border:solid 1px #ee0; background:#ffc;"></div>
</body>

 

先执行p的事件,再执行div的事件,最后执行body事件.

事件监听

事件监听准确一点讲可以说是js引擎对用户鼠标、键盘、窗口事件等动作的监视进行的操作,也就是针对用户相应的操作进行附加事件,常用的类似 btnAdd.οnclick="alert(’51obj.cn’)"就是一种简单的附加事件,只不过这种方法不支持附加多个事件以及删除事件。以下代 码将实现附加事件后删除事件(IE下):

<script type="text/javascript">
<!–
var oP;
function window.onload(){
    oP=document.getElementById("pContent");
    oP.attachEvent("onclick",Click);
}
function Click(){
    alert("做点什么吧");
    oP.detachEvent("onclick",Click);
}
//–>
</script>
</head>

<body>
<p id="pContent" style="border:solid 1px #d00; background:#cff;">点击</p>

IE不能称为标准的DOM浏览器,即使是最新的IE8,相对于标准DOM如Firefox、Opera等,它是个“异类”;在Firefox中才真正有称为事件监听的函数addEventListener,如下例

<script type="text/javascript">
<!–
window.οnlοad=function(){
    var oBtn=document.getElementById("btn");
    oBtn.addEventListener("click",Click,false);
}
function Click(){
    alert("触发click事件");
}
//–>
</script>
<button id="btn">点击</button>


从上面两个例子看出attachEvent在Firefox中并不支持,IE也不支持addEventListener.因此需要使用兼容性的方法。

 

<script type="text/javascript">
<!–
var oBtn;
window.οnlοad=function(){
    oBtn=document.getElementById("btn");
    if(window.addEventListener){
        oBtn.addEventListener("click",Click,false);
    }//FF,Opera…
    else if(window.attachEvent){
        oBtn.attachEvent("onclick",Click,false);
    }//IE
    else{
        oBtn.οnclick=Click;
    }//Other
}

function Click(){
    alert("事件只执行一次");
    if(window.addEventListener){
        oBtn.removeEventListener("click",Click,false);
    }//FF
    else if(window.attachEvent){
        oBtn.detachEvent("onclick",Click);
    }
    else{
        oBtn.οnclick=null;
    }
}
//–>
</script>
</head>

<body>
<button id="btn">www.51obj.cn&raquo;&raquo;</button>
</body>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值