14

我正在尝试通过交叉点观察者调用回调。

我希望它target成为style: "position: fixed"并通过 style.top.

我还指定了作为目标祖先的根元素style: "position: relative"

但是当目标和观察者相交时,不会触发回调函数。

我错过了一些限制吗?

这是我输入的内容:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>IO</title>
</head>
<body>
<div style="height: 200px;width: 100%;background: violet" class="upper">aaa</div>
<div style="position:relative;height: 200px;width: 100%;background: blueviolet" id="middle">bbb
    <div id="target" style="position:fixed;top: 0px;width: 50px;height: 50px;background: firebrick">ccc</div>
</div>
<script>
    let options = {
        root: document.getElementById("middle"),
        rootMargin: '0px',
        threshold: 0
    };
    let observer = new IntersectionObserver(entry => {
        console.log("observer's acting.")
    }, options);

    let target = document.getElementById("target");
    observer.observe(target);

    let stepping = 0;

    let cb = () => {
        target.style.top = stepping + 'px';
        stepping += 4;
        if (stepping < 300){
            setTimeout(cb, 100);
        }
    };

    window.addEventListener("click", () => {
        cb();
    })
</script>
</body>
</html>

这是一个codepen演示: codepen demo

您可以单击页面中的任意位置开始移动ccc块。

4

2 回答 2

5

元素position: fixed相对于视口定位,并且视口移动。因此,固定定位的元素会在您滚动时“移动”。即使#target是 的孩子#middle,我相信 IntersectionObserver,无论它在后台使用什么来计算是否target进入/离开root,都不会触发回调,因为target是在文档流之外。

这是一个相关的问题。与此问题相关的互联网上没有太多内容:https ://bugs.chromium.org/p/chromium/issues/detail?id=653240

注意:position: absolute在目标上设置确实会在进入和离开视口时触发回调。

于 2018-11-21T00:13:58.380 回答
0

在我的例子中,我的根元素(位置:固定)与我想要观察的元素(可滚动)处于相同的 DOM 层次结构级别,并且没有触发任何事件。

<div id="root" style="position:fixed"></div>
<div id="scrollable"></div>

当我将元素放在根中时,事件触发了。

<div id="root" style="position:fixed">
  <div id="scrollable"></div>
</div>
于 2022-03-04T13:05:59.943 回答