javascript实现某元素显示隐藏带动其他元素隐藏显示

项目场景:

提示:前几天运营想要实现一个效果,当滚动轮滑过某个视口时,当该视口不可时,悬浮框显示,当该视口上滑可见时,悬浮框可见。可以看到上方底色的背景显示时,右下角黑色悬浮框隐藏,上方背景隐藏时,下方悬浮框隐藏。因为不想用jquery以及通过offfsetHeight计算等实现,采用了intersectionObserver实现,
在这里插入图片描述

解决方案:

提示:开始时总想着监听下方背景板,但后来发现无法实现,改为监听上方背景板实现。`

<!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>测试intersection</title>
    <style>
        .one {
            height: 200vh;
            background-color: aqua;
        }

        .two {
            height: 100vh;
            background-color: aquamarine;
        }

        .aside {
            position: fixed;
            bottom: 100px;
            right: 0px;
            display: none;
            width: 100px;
            background-color: black;
        }
    </style>
</head>

<body>
    <div class="one"></div>
    <div class="two"></div>
    <div class="aside">aoaoaooa</div>

    <script type="text/javascript">


        let imgs = document.getElementsByClassName('one')[0];
        let aside = document.getElementsByClassName('aside')[0]

        const config = {
            rootMargin: '0px',
            threshold: 0
        }
        let observer = new IntersectionObserver((entries, self) => {
            entries.forEach((entry) => {
                if (entry.isIntersecting) {
                    console.log(entry.rootBounds);
                    aside.style.display = 'none'
                } else {
                    aside.style.display = 'block'
                }
            })
        }, config)
        observer.observe(imgs)

    </script>
</body>

</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值