gpt4 book ai didi

javascript - 当用户以最佳性能滚动时,如何检测视口(viewport)中的当前元素?

转载 作者:行者123 更新时间:2023-12-02 21:32:30 26 4
gpt4 key购买 nike

我有一个包含大约 30 张卡片的 div。我想要实现的是:每次用户滚动时,我都会检索当前视口(viewport)中的卡片并将它们视为“已访问”。例如,在第一次滚动之后,视口(viewport)中的当前卡片是 id = 1,2,3,4 的卡片,我将在第一次滚动后将它们标记为已访问。如何以最佳性能实现这一目标?

<div id="search-results">
<div class="search-card" id="card-1"></div>
<div class="search-card" id="card-2"></div>
<!-- 30 elements with class = "search-card" -->
</div>

我尝试按照建议使用 Intersection Observer API,但我认为我做错了什么?它不会观察...它仅在页面加载时触发。我应该添加滚动事件还是其他什么?

var options = {
root: document.querySelector('#search-results'),
rootMargin: '0px',
threshold: 1.0
};

var callback = function(entries, observer) {
entries.forEach(function(entry) {

if (entry.isIntersecting) {
console.log(entry.target)
}
else {
console.log('not intersecting')
}
});
};

const observer = new IntersectionObserver(callback, options);

var targets = document.querySelectorAll('.search-card');

targets.forEach(function(target) {
observer.observe(target)
});

最佳答案

设置 root属性至null 。这意味着文档的根 ( <html> ) 将用于检查该元素在根的视口(viewport)中是否可见。由于您的网站可能会在根元素中滚动,因此它将检查观察到的元素相对于根元素是否可见,该根元素溢出到屏幕之外。因此它会检查元素是否在溢出边界内。

当使用没有溢出的搜索容器时,它将检查该元素在 #search-results 的上下文中是否可见。容器,它们始终是容器,因为没有任何元素超出容器的约束。

还可以使用带有数字(整数或 float )的数组来表示 threshold属性(property)。 0表示仅观察到的元素的单个像素必须在 View 中,而 1意味着 100% 的元素必须在 View 中才能触发回调函数。

查看下面的示例。

var options = {
root: null,
rootMargin: '0px',
threshold: [0]
};

var callback = function(entries, observer) {
entries.forEach(function(entry) {

if (entry.isIntersecting) {
entry.target.classList.add('is-seen');
observer.unobserve(entry.target);
}
});
};

const observer = new IntersectionObserver(callback, options);

var targets = document.querySelectorAll('.search-card');

targets.forEach(function(target) {
observer.observe(target)
});
#search-results {
background: #f7f7f7;
padding: 15px;
}

.search-card {
display: block;
height: 200px;
width: 100%;
background: #ffffff;
border: 1px solid #d0d0d0;
border-radius: 5px;
margin-bottom: 15px;
transition: background-color 150ms 500ms ease-in-out;
}

.search-card.is-seen {
background: #d0d0d0;
}
<div id="search-results">
<div class="search-card" id="card-1"></div>
<div class="search-card" id="card-2"></div>
<div class="search-card" id="card-3"></div>
<div class="search-card" id="card-4"></div>
<div class="search-card" id="card-5"></div>
<div class="search-card" id="card-6"></div>
<div class="search-card" id="card-7"></div>
<div class="search-card" id="card-8"></div>
<div class="search-card" id="card-9"></div>
<div class="search-card" id="card-10"></div>
<div class="search-card" id="card-11"></div>
<div class="search-card" id="card-12"></div>
</div>

关于javascript - 当用户以最佳性能滚动时,如何检测视口(viewport)中的当前元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60585349/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com