div层次嵌套问题

今天遇到一个问题,就是在外层div上设置监听函数:

οnmοusemοve="changeI()" οnmοuseοver="changeJ()" οnmοuseοut="changeK()

但是当鼠标在该div内部移动时会触发onmouseout函数,但是我的鼠标没有移开外层div的范围啊,怎么会调用onmouseout函数呢?

原来div是嵌套关系的,当鼠标移动到内层div管辖的范围时,就是出了外层div的监听范围,所以会调用onmouseout函数。

有一个办法可以解决这个问题,就是为这个外层div创建一个兄弟div,也就是并行的意思,大小和该div一样,然后调整样式

使这个兄弟div完全罩住刚刚的外层div,这样对这个兄弟的div设置监听:οnmοusemοve="changeI()" οnmοuseοver="changeJ()" οnmοuseοut="changeK()

就可以达到效果了。但是代价就是原来div内部的触发都无效了。


--------------------------------------2012.08.07

今天又查了一下,发现了一个更好的办法:

function d_2(obj,e)
{
    var e = window.event || e, relatedTarget = e.toElement || e.relatedTarget;
    while(relatedTarget && relatedTarget != obj)
    relatedTarget = relatedTarget.parentNode;
    if(!relatedTarget)
       {
        obj.className="haha";
        document.getElementById('k').innerHTML = k++;
       }

οnmοuseοver="d_2(this,event)" οnmοuseοut="changeK()


这个函数的功能是判断移出区域时,移出的div是否是当前div,如果是就进行相应的操作。

当然移入也是可以调用这个函数的,只是要改一下:


    if(!relatedTarget)
       {
        obj.className="haha";
        document.getElementById('k').innerHTML = k++;

       }

里面的内容,让他做移入的操作

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值