如何使用交叉点观察器显示/隐藏元素

Posted

技术标签:

【中文标题】如何使用交叉点观察器显示/隐藏元素【英文标题】:how to use intersection observer to show/hide an element 【发布时间】:2022-01-11 22:45:01 【问题描述】:

如果滚动页面看不到wrapt,则需要显示nava 反之亦然 - 如果 wrapt 可见,则隐藏 nava 这段 JS 代码有什么问题?

let io = new IntersectionObserver((entries) => 
    entries.forEach(entry => 
        if(entry.isIntersecting)modify(entry.target);
        elserevert(entry.target);
    );
);

function modify(el)
  if(el.id == "wrapt")$(nava).slideUp();


function revert(el)
  if(el.id == "wrapt")$(nava).slideDown();


$(document).ready(function()
    io.observe(document.querySelector('#wrapt'));
);
.nava
display:none
height:25px;
background:orange;
position:relative;
z-index:9;

.wrapt
height:54px;
background:lightblue;

.story
height:200vh;
background:#ddd;
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class='nava' id='nava'></div>
<div class='wrapt' id='wrapt'></div>
<div class='story'></div>

【问题讨论】:

【参考方案1】:

JS 部分没有问题,只有 CSS。 我已经修改了nava 类,所以当页面向下滚动时它会可见:

.nava 
  display: none;
  height:25px;
  background: orange;
  position: fixed;
  width: 100%;
  z-index: 9;
  top: 0;
  left: 0;

let io = new IntersectionObserver((entries) => 
  entries.forEach(entry => 
    if (entry.isIntersecting) 
      modify(entry.target);
     else 
      revert(entry.target);
    
  );
);

function modify(el) 
  if (el.id == "wrapt") 
    $(nava).slideUp();
  


function revert(el) 
  if (el.id == "wrapt") 
    $(nava).slideDown();
  


$(document).ready(function() 
  io.observe(document.querySelector('#wrapt'));
);
.nava 
  display: none;
  height:25px;
  background: orange;
  position: fixed;
  width: 100%;
  z-index: 9;
  top: 0;
  left: 0;


.wrapt 
  height: 54px;
  background: lightblue;


.story 
  height: 200vh;
  background: #ddd;
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class='nava' id='nava'></div>
<div class='wrapt' id='wrapt'></div>
<div class='story'></div>

【讨论】:

hmm...它有效,但nava 在整个身体之外。我尝试使用位置absolute - 不起作用。有什么建议吗? 不确定想要的结果是什么

以上是关于如何使用交叉点观察器显示/隐藏元素的主要内容,如果未能解决你的问题,请参考以下文章

交叉点观察者 页面上已经存在的动画元素偶尔会起作用

如何使用 pandas 创建交叉表来显示随机森林预测器的预测结果?

html5 输入元素“日期” - 如何显示日历元素

在笑话和打字稿中模拟交叉点观察者

如何隐藏一个在页面上多个位置使用的类,*仅来自特定元素*,使用 css 媒体查询

如何使用 Vue.js 显示和隐藏引导微调器?