javascript - 从顶部和底部偏移固定 div

标签 javascript jquery css css-position

我的页面右侧有一个固定的 div。我将其设置为随页面滚动而不与页脚重叠,效果很好。问题是向上滚动时它与导航重叠。有没有办法让它对两者都有效?我尝试创建一个新函数

function checkOffset() {
    var a = $(document).scrollTop() + window.innerHeight;
    var b = $('#footer').offset().top;

    if (a < b) {
        $('#social-float').css('bottom', '10px');
    } else {
        $('#social-float').css('bottom', (10 + (a - b)) + 'px');
    }
}
$(document).ready(checkOffset);
$(document).scroll(checkOffset);
<nav class="nav">Nav Sample</nav>

<div id="social-float">
    <div class="sf-twitter">twitter</div>
    <div class="sf-facebook">facebook</div>
</div>

<div id="footer">footer sample</div>

最佳答案

Here检查这个 fiddle 的解决方案。 我在页面上添加了调试文本,并且还考虑了导航栏可能由于顶部的其他 div 而发生偏移的事实。

/** 
 * This function checks for both top and bottom edges to position itself
 * on the page
 */
function checkOffset() {
    var documentTop = $(document).scrollTop();
    var currentScrollOffset = documentTop + window.innerHeight;
    var footerOffset = $('#footer').offset().top;
    var navbarEffectiveHeight = $('.nav').outerHeight() + $('.nav').offset().top;
    var $fixedElem = $('#social-float');
    var fixedElemHeight = $fixedElem.outerHeight();

		// until page scroll crosses navbar bottom edge (offset)
    if (currentScrollOffset < navbarEffectiveHeight) {
    		$fixedElem.css('top', (currentScrollOffset + 10) + 'px');
        $fixedElem.css('bottom', 'unset');
    // page scroll crossed navbar bottom edge but not to extend of the height of fixed div
    // including the top and bottom spacing for it which is 20px
    } else if (currentScrollOffset < navbarEffectiveHeight + fixedElemHeight + 20) {
    		$fixedElem.css('top', (window.innerHeight - (currentScrollOffset - navbarEffectiveHeight) + 10) + 'px');
        $fixedElem.css('bottom', 'unset');
    // page scroll hasn't crossed footer top edge (offset)
    } else if (currentScrollOffset < footerOffset) {
        $fixedElem.css('bottom', '10px');
        $fixedElem.css('top', 'unset');
    // page scroll crossed footer top edge (offset)
    } else {
        $fixedElem.css('bottom', (10 + (currentScrollOffset - footerOffset)) + 'px');
        $fixedElem.css('top', 'unset');
    }
}


$(document).ready(checkOffset);
$(document).scroll(checkOffset);

关于javascript - 从顶部和底部偏移固定 div,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61019999/

相关文章:

css - 是否可以将 !important 作为参数/选项传递给 LESSCSS 混合?

html - CSS 背景颜色 + 悬停时图像淡入淡出效果

javascript - 多个级别的高度 100%

JavaScript for 循环错误

javascript - 如何在 JavaScript 中创建配分函数。使用以下指南

javascript - 我可以使用 jQuery.extend 来模拟方法重载吗?

javascript - 如何添加一个类,该类会递增到使用 jquery 附加的元素

html - 水平对齐图像并 overflow hidden

javascript - 使用 Backbone.js 默默地将 url 更改为以前的

javascript - 如何在Javascript中使用file_get_contents和json_decode