向下滚动隐藏导航栏,向上滚动显示

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
body{
margin:0;
padding: 0;
height: 3000px;
}
#fix_nav{background-color: #ccc;}
.nav{width:980px; margin:0 auto;}
.nav li{display:inline-block; *display:inline; *zoom:1; margin:0 10px;}
.nav li a{display:block; padding:5px 10px;text-decoration: none;color: #fff}
.fixed-nav{
position: fixed;
width:100%;
top:-40px; 
-webkit-transition: top .5s;
 -moz-transition: top .5s;
 -o-transition: top .5s;
 transition: top .5s;
}
.fixed-nav-appear{top:0;}
.fix_sec{
position: fixed;
width:100%;
top:0;
z-index: 999;
-webkit-transition: top .5s;
-moz-transition: top .5s;
-o-transition: top .5s;
transition: top .5s;
}
</style>
<script src="jquery.min.js"></script>
</head>
<body>
<div id="fix_nav">
<ul class="nav">
<li><a href="#">首页</a></li>
<li><a href="#">PHP</a></li>
<li><a href="#">Css/Div</a></li>
<li><a href="#">Javascript交互</a></li>
</ul>
</div>
<section>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
<div class="content">这里是内容区块</div>
</section>
<script>
//设置导航滚动到多少再消失(可自己设置)
var fix_length = 200;


// 获取导航节点
var $nav = $('#fix_nav');


// 获取导航节点距离顶部位置
var navTop = $nav.offset().top; 


// 获取导航的高度(包括border)
var navH = $nav.outerHeight();


// 设置初始位置
var winTop_1=0;


// 判断浏览器宽度(可用于自适应是否启用此效果)
var winWidth=$(window).width();




// 判断滚动条


$(window).on('scroll',function(){
// 滚动条距离顶部距离
var winTop_2 = $(window).scrollTop();
//开始浮动,不过不显示
if(winTop_2>navTop && winWidth>980){
$nav.addClass('fixed-nav');
if(winTop_2>winTop_1){
$nav.addClass('fix_sec');
if(winTop_2>fix_length){
$nav.removeClass('fix_sec');
}
}
}else{
$nav.removeClass('fixed-nav');
}
//判断鼠标向上滚动,显示出来
if(winTop_2>winTop_1 && winWidth>980){
$nav.removeClass('fixed-nav-appear');
}else if(winTop_2<winTop_1){
$nav.addClass('fixed-nav-appear');
$nav.removeClass('fix_sec');
}
// 滚动后距离赋值
winTop_1 = $(window).scrollTop();
})
</script>
</body>
</html>
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值