在拥有滚动条元素内滚动时,判断其子元素是否出现(达到可视区域)公式


prtyaa
prtyaa 2023-12-26 18:38:32 65690
分类专栏: 资讯

问题描述

网上的帖子大多数是:判断一个元素是否在可视区域中

而帖子中举的例子,也是以浏览器最外层body/html的滚动条为例子,进行讲解,基本上都是如下的效果图:

注意这里的滚动条是最外层的
动图封面
 
  • 实际上,我们页面的滚动条,有时,并不是以最外层的body或者html进行滚动的
  • 可能是页面中间的某一个dom元素可以滚动
  • 我们需要判断这个dom滚动元素内的某一个小dom目标元素何时出现,何时达到可视区域
  • 这里的可视区域是能看到,和最外层的那个滚动条没有关系的
  • 如下效果图

如需求:当红色盒子在内层滚动条滚动中出现时,就更改对应dom元素背景色为粉红色

动图封面
 
注意这里有两个滚动条,我们的需求是里面的滚动条滚动时,去做对应控制

公式提出

  • 其实也很简单,首先我们分析一些元素层级结构。
  • 最外层的肯定是bodyhtml,这个不用管它
  • body标签内部,有一个<div class="scrollBox"></div>,这个dom元素拥有滚动条
  • 而在.scrollBoxdom元素内,还有一个目标元素<div class="target"></div>,看看这个目标元素.target何时出现,何时达到可视区域

公式:

滚动距离出现 = .target距顶部高度 - .scrollBox距顶部高度 - .scrollBox自身高度

滚动距离出现 = .target距顶部高度 - .scrollBox距顶部高度 - .scrollBox自身高度

滚动距离出现 = .target距顶部高度 - .scrollBox距顶部高度 - .scrollBox自身高度

或:

边界值 = 目标元素距顶部高度 - 滚动盒子容器距顶部高度 - 滚动盒子容器自身高度

边界值 = 目标元素距顶部高度 - 滚动盒子容器距顶部高度 - 滚动盒子容器自身高度

边界值 = 目标元素距顶部高度 - 滚动盒子容器距顶部高度 - 滚动盒子容器自身高度

即,当滚动的距离超过这个边界值时,目标元素就会出现

这里的边界值,一定是初始边界值,就是要提前算好,最好存一份,因为滚动的话,会更改相应距离位置的

复制粘贴代码看效果更好理解:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .scrollBox {
            width: 100%;
            height: 300px;
            background-color: #ccc;
            /* 拥有滚动条 */
            overflow-y: auto;
        }

        .target {
            width: 60px;
            height: 60px;
            background-color: red;
        }
    </style>
</head>

<body>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <div class="scrollBox">
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <h1>孙悟空</h1>
        <div class="target"></div>
    </div>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <script>
        let scrollBoxDom = document.querySelector('.scrollBox')
        let targetDom = document.querySelector('.target')
        // 注意!这里的边界值,是原始的位置的值,因为滚动的话,会更改元素的getBoundingClientRect的相关值
        let boundaryValue = targetDom.getBoundingClientRect().top - scrollBoxDom.getBoundingClientRect().top - scrollBoxDom.offsetHeight
        // 边界值 = 目标元素距离顶部高度 - 滚动盒子容器距离顶部高度 - 滚动盒子容器自身的高度
        function callBack() {
            if (scrollBoxDom.scrollTop > boundaryValue) {
                console.log('在可视区域');
                scrollBoxDom.style.backgroundColor = 'pink'
            } else {
                console.log('不在可视区域');
                scrollBoxDom.style.backgroundColor = '#ccc'
            }
        }
        scrollBoxDom.addEventListener('scroll', callBack)
    </script>
</body>

</html>

附-以浏览器最外层body/html的滚动条为例子代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            background-color: #ccc;
        }

        .target {
            width: 60px;
            height: 60px;
            background-color: red;
        }
    </style>
</head>

<body>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <h1>孙悟空</h1>
    <div class="target"></div>
    <script>
        window.onload = () => {
            let targetDom = document.querySelector('.target') // 目标元素dom
            function callBack() {
                const top = targetDom.getBoundingClientRect().top; // 目标元素dom距离顶部的高度
                if (top <= window.innerHeight) { // 当top小于等于文档显示区域的高时,就进入可视区域了
                    console.log('在可视区域');
                    document.body.style.background = 'pink'
                } else {
                    console.log('不在可视区域'); // 当top大于文档显示区域的高时,就离开可视区域了
                    document.body.style.background = '#ccc'
                }
            }
            window.addEventListener('scroll', callBack);
        }
    </script>
</body>

</html>

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=31027
赞同 0
评论 0 条
prtyaaL1
粉丝 1 发表 2554 + 关注 私信
上周热门
银河麒麟添加网络打印机时,出现“client-error-not-possible”错误提示  1523
银河麒麟打印带有图像的文档时出错  1442
银河麒麟添加打印机时,出现“server-error-internal-error”  1233
统信操作系统各版本介绍  1153
统信桌面专业版【如何查询系统安装时间】  1149
统信桌面专业版【全盘安装UOS系统】介绍  1106
麒麟系统也能完整体验微信啦!  1060
统信【启动盘制作工具】使用介绍  713
统信桌面专业版【一个U盘做多个系统启动盘】的方法  656
信刻全自动档案蓝光光盘检测一体机  561
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
如何玩转信创开放社区—从小白进阶到专家 15
信创开放社区邀请他人注册的具体步骤如下 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

添加我为好友,拉您入交流群!

请使用微信扫一扫!