offset系列 + scroll系列 + 冒泡问题

本文详细解析了DOM中offset系列属性(offsetTop, offsetLeft, offsetHeight, offsetWidth)的使用方法,以及scrollTop和scrollLeft的兼容性问题。同时介绍了事件冒泡现象及其解决策略,包括return false和event.stopPropagation()的运用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、offset系列包括offsetTop,offsetLeft,offsetHeight,offsetWidth;

  • offsetHeight 和 offsetWidth :获取到的宽高包括padding的值;
  • offsetLeft 和 offsetTop :
    • 同一层(是否脱离文档流)获取距离父元素 left 和 top 的值
    • 包括自身的margin值
    • 如果是嵌套标签,子元素还应包括父元素的padding值

2、scrollTop 和 scrollLeft在获取的时候要注意浏览器兼容问题,可以用一下代码兼容:

var theTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;

3、元素嵌套之后,给父元素和子元素都设置了事件触发的话会出现冒泡现象,在子元素事件被触发时,父元素事件也被触发。可用一下方法解决:

  • 在子元素的触发执行代码最后加上 return false;
    (会阻值默认行为,如a标签的超链接跳转)
  • 给子元素加上 event.stopPropagation() (不会阻值默认行为);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值