jquery - 工作脚本不起作用(代码正确 - 缺少一些东西)

标签 jquery html css menu hide

我正在尝试复制一个脚本,但由于某种原因它无法正常工作。该脚本应该在向下滚动时隐藏菜单栏,并在用户开始向上滚动时显示它。这些是我的文件,但由于某种原因它不起作用......实际代码肯定有效。我想我缺少一些让它工作的小东西。

来源:http://jsfiddle.net/mariusc23/s6mLJ/31/

HTML:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<link rel="stylesheet" type="text/css" href="CSS/stylesheet-menu.css" media="screen" />
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script type="text/javascript" src="Menu-JS/javascript-menu.js"></script>
</head>

<body>
<header class="nav-down">
    This is your menu.
</header>
<main>
    This is your body.
</main>
<footer>
    This is your footer.
</footer>
</body>

CSS:

body {
    padding-top: 40px;
}

header {
    background: #f5b335;
    height: 40px;
    position: fixed;
    top: 0;
    transition: top 0.2s ease-in-out;
    width: 100%;
}

.nav-up {
    top: -40px;
}

main {
   background:url(
data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAPklEQVQYV2O8dOnSfwYg0NPTYwTRuAAj0QqxmYBNM1briFaIzRbi3UiRZ75uNgUHGbfvabgfsHqGaIXYPAMAD8wgC/DOrZ4AAAAASUVORK5CYII=
   ) repeat;
    height: 2000px;
}

footer { background: #ddd;}
* { color: transparent}

JS:

// Hide Header on on scroll down
var didScroll;
var lastScrollTop = 0;
var delta = 5;
var navbarHeight = $('header').outerHeight();

$(window).scroll(function(event){
    didScroll = true;
});

setInterval(function() {
    if (didScroll) {
        hasScrolled();
        didScroll = false;
    }
}, 250);

function hasScrolled() {
    var st = $(this).scrollTop();

    // Make sure they scroll more than delta
    if(Math.abs(lastScrollTop - st) <= delta)
        return;

    // If they scrolled down and are past the navbar, add class .nav-up.
    // This is necessary so you never see what is "behind" the navbar.
    if (st > lastScrollTop && st > navbarHeight){
        // Scroll Down
        $('header').removeClass('nav-down').addClass('nav-up');
    } else {
        // Scroll Up
        if(st + $(window).height() < $(document).height()) {
            $('header').removeClass('nav-up').addClass('nav-down');
        }
    }

    lastScrollTop = st;
}

最佳答案

缺少http:在:

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>

这可能是个问题:)

关于jquery - 工作脚本不起作用(代码正确 - 缺少一些东西),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22114806/

相关文章:

jquery - 使用 jQuery ui.sortable 时未触发鼠标悬停事件

javascript - 通过id获取元素并将其放入bootstrap col中

javascript - 如何在 html 5 canvas 中删除区域的剪辑

asp.net - 使用标签样式而不是类样式

html - 表中一行三个元素

javascript - 如何在 HTML 元素之后放置文本光标?

javascript - 居中 'container-fluid' 幻灯片和视频播放器

带名称的 JavaScript 提示

html - 从背景中切割出像素线的文本

html - 强制表格单元格 div 内的表格填充 100% 宽度