如何使用交叉点观察器显示/隐藏元素
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 创建交叉表来显示随机森林预测器的预测结果?