使用javascript确定从div顶部到窗口顶部的距离

IT技术 javascript jquery
2021-02-03 05:33:09

如何确定 div 的最顶部到当前屏幕顶部之间的距离?我只想要到当前屏幕顶部的像素距离,而不是文档顶部。我已经尝试了一些像.offset()和 之类的东西.offsetHeight,但我就是无法理解它。谢谢!

5个回答

您可以使用.offset()获取与document元素相比的偏移量,然后使用元素的scrollTop属性window来查找用户向下滚动页面的距离:

var scrollTop     = $(window).scrollTop(),
    elementOffset = $('#my-element').offset().top,
    distance      = (elementOffset - scrollTop);

distance变量现在保存从#my-element元素顶部到顶部折叠的距离

这是一个演示:http : //jsfiddle.net/Rxs2m/

请注意,负值表示元素位于顶部折叠上方。

@ThessaVerbruggen 您可以检查distance变量以查看其值是否正确,120但我建议您检查范围而不是确切数字。例如,如果您使用鼠标滚轮滚动,则很可能会跳过 120。因此,如果您尝试在元素位于顶部折叠的 120 像素内时应用一些 CSS 或其他内容,则可以使用if (distance < 120) { /* do something */}. 这是一个更新的演示:jsfiddle.net/na5qL91o
2021-03-25 05:33:09
如果我这样做会出现一个问题:当我滚动时,粘性部分会闪烁。我猜是因为它在我滚动时重新计算。知道如何解决这个问题吗?我的代码: $(window).on('scroll', function () { var scrollTop = $(window).scrollTop(), elementOffset = $('#secondary').offset().top, distance = (elementOffset - scrollTop); if (distance < 120) { $('#secondary').addClass('sticky'); } else { $('#secondary').removeClass('sticky'); } });
2021-03-31 05:33:09
如何检查距离是否为特定数字?如果元素距顶部 120 像素,我想让它具有粘性
2021-04-08 05:33:09

香草:

window.addEventListener('scroll', function(ev) {

   var someDiv = document.getElementById('someDiv');
   var distanceToTop = someDiv.getBoundingClientRect().top;

   console.log(distanceToTop);
});

打开浏览器控制台并滚动页面以查看距离。

这仅在用户未滚动页面时才有效。否则distanceToTop返回的是相对的(如果用户滚动过去,甚至可以是负数)。要考虑到这一点,请使用window.pageYOffset + someDiv.getBoundingClientRect().top
2021-03-22 05:33:09
这也是我需要的。我正在使用 Vue-toasted 库,它只允许在屏幕上的绝对位置显示 toast。我希望 toast 显示在我在表格中单击的按钮附近,并且最终需要在滚动事件中使用 getBoundingClientRect().top 。我也在调整大小事件中做了同样的事情。可能要考虑在像这样计算到屏幕顶部的距离时添加这一点 - 永远不知道客户端最终会做什么。
2021-03-23 05:33:09
@ty OP 正在寻找到屏幕顶部的距离,而不是到文档顶部的距离 - 在这种情况下负值有效
2021-04-07 05:33:09

这可以完全使用 JavaScript来实现

我看到lynx在对问题的评论中回答了我想写的答案

但无论如何我都会写下答案,因为就像我一样,人们有时会忘记阅读评论。

因此,如果您只想从屏幕窗口顶部获取元素的距离(以像素为单位),您需要执行以下操作:

// Fetch the element
var el = document.getElementById("someElement");  

使用getBoundingClientRect()

// Use the 'top' property of 'getBoundingClientRect()' to get the distance from top
var distanceFromTop = el.getBoundingClientRect().top; 

而已!

希望这对某人有所帮助:)

@MerianosNikos 谢谢。我很高兴它有帮助:)
2021-04-03 05:33:09
getBoundingClient() 不起作用,而是 .getBoundingClientRect()
2021-04-04 05:33:09
但这只有在您没有在页面中间重新加载时才有效,对吗?
2021-04-05 05:33:09
@SagiveSEO 我不明白。你能详细说明你的问题吗?
2021-04-05 05:33:09
很棒的工作@MohammedFurqanRahamathM。非常感谢您的回答 :) 它就像一个魅力!:)
2021-04-07 05:33:09

我用过这个:

                              myElement = document.getElemenById("xyz");
Get_Offset_From_Start       ( myElement );  // returns positions from website's start position
Get_Offset_From_CurrentView ( myElement );  // returns positions from current scrolled view's TOP and LEFT

代码:

function Get_Offset_From_Start (object, offset) { 
    offset = offset || {x : 0, y : 0};
    offset.x += object.offsetLeft;       offset.y += object.offsetTop;
    if(object.offsetParent) {
        offset = Get_Offset_From_Start (object.offsetParent, offset);
    }
    return offset;
}

function Get_Offset_From_CurrentView (myElement) {
    if (!myElement) return;
    var offset = Get_Offset_From_Start (myElement);
    var scrolled = GetScrolled (myElement.parentNode);
    var posX = offset.x - scrolled.x;   var posY = offset.y - scrolled.y;
    return {lefttt: posX , toppp: posY };
}
//helper
function GetScrolled (object, scrolled) {
    scrolled = scrolled || {x : 0, y : 0};
    scrolled.x += object.scrollLeft;    scrolled.y += object.scrollTop;
    if (object.tagName.toLowerCase () != "html" && object.parentNode) { scrolled=GetScrolled (object.parentNode, scrolled); }
    return scrolled;
}

    /*
    // live monitoring
    window.addEventListener('scroll', function (evt) {
        var Positionsss =  Get_Offset_From_CurrentView(myElement);  
        console.log(Positionsss);
    });
    */
+1 用于显示 element.offsetTop 存在。element.getBoundingClientRect().top 给了我奇怪的行为。我正在寻找从网页顶部到元素顶部的距离。
2021-03-19 05:33:09

我使用此功能来检测元素是否在视口中可见

代码:

const vh = Math.max(document.documentElement.clientHeight || 0, window.innerHeight || 0);
$(window).scroll(function(){
var scrollTop     = $(window).scrollTop(),
elementOffset = $('.for-scroll').offset().top,
distance      = (elementOffset - scrollTop);
if(distance < vh){
    console.log('in view');
}
else{
    console.log('not in view');
}
});