js 如何检测一个元素是否在视窗中(浏览器可见窗口)

如何检测一个元素是否在视窗中(判断元素是否在浏览器可见窗口)

/**
 *  如何检测一个元素是否在视窗中(判断元素是否在浏览器可见窗口)
 * @param {Object} elm
 */
export function checkVisible(elm) {
  if (!elm) return
  var rect = elm.getBoundingClientRect()
  //获取当前浏览器的视口高度,不包括工具栏和滚动条
  //document.documentElement.clientHeight兼容 Internet Explorer 8、7、6、5
  var viewHeight = Math.max(
    document.documentElement.clientHeight,
    window.innerHeight
  )
  //bottom top是相对于视口的左上角位置
  //bottom大于0或者top-视口高度小于0可见
  return !(rect.bottom < 0 || rect.top - viewHeight >= 0)
}

//调用
  const eleImg= document.querySelector(".dynamic-img")
  if (checkVisible(eleImg)) {
      //可在此编辑代码
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值