jQuery实现页面导航内容定位效果,并支持内容切换

需求

页面向下滚动时,需要将顶部的搜索栏信息和导航菜单吸顶,并且,搜索栏信息和导航菜单之间可以切换。

效果

https://www.iguopin.com/index.php?m=&c=index&a=index

代码实现

HTML

	<div class="nav-search">
		<div class="container">
			<div class="navbar-header">
				<a class="navbar-brand" href="#">
					<img alt="Brand" src="../public/images/igplogo2.png" class="header-brand">
				</a>
			</div>
			<div class="right_part  noprint">
				<form class="ip-group">
					<div class="ip-box">
						<div class="type">
							<div class="text"></div>
							<i class="layui-icon layui-icon-down" style="font-size: 18px;cursor: pointer;"></i>
							<div class="dpdown">
								<div class="option" id="1">社会招聘</div>
								<div class="option" id="2">校园招聘</div>
								<div class="option" id="3">高端职位</div>
								<div class="option" id="4">实习职位</div>
							</div>
						</div>
						<input
							type="text"
							name="jobkey"
							id="top_search_input"
							value=""
							placeholder="请输入职位或企业名称"/>
					</div>
					<input type="submit" class="ip-btn" value="搜索">
					<input type="hidden" name="act" id="top_search_type" value="QS_jobslist"/>
				</form>
				<div class="nav-btn">
					<span class="nav-text">导航</span>
					<span class="iconfont icon-other"></span>
				</div>
				<div class="qrcodes">
					<img class="qrcode qr1" src="../public/images/index/gp_qrcode.png"></img>
					<img class="qrcode qr2" src="../public/images/index/gpfb_qrcode.png"></img>
					<div class="qrcode-tip-box">
						<span class="tip1 active">关注最新招聘资讯</span>
						<span class="tip2">获取简历投递状态</span>
					</div>
				</div>
				<div class="clear"></div>
			</div>
		</div>
	</div>
...
...
...
<div class="link-nav">
  <div class="container">
    <ul class="nav navbar-nav site_link">
      <li><a target="_blank" href="www.iguopin.com">国聘行动</a></li>
      <li><a target="_blank" href="https://zhaogong.iguopin.com/">线上招工</a></li>
      <li><a target="_blank" href="https://zhaogong.iguopin.com/abroad">一带一路</a></li>
    </ul>
    <div class="clearfix"></div>
  </div>
</div>

css

.nav-search {
	 100%;
	background-color: #fff;
	z-index: 1000;
}
.navbar .container .navbar-header {
    margin-right: 0;
    float: none;
    margin-left: 0;
     20%;
}
.navbar .container .right_part {
	align-items: center;
     80%;
}
.nav-btn {
	float: right;
	display: none;
	 70px;
	margin-left: 40px;
	font-size: 16px;
	color: #c90808;
	line-height: 85px;
	cursor: pointer;
}
.nav-search-fixed {
	position: fixed;
	top: 0;
	-webkit-box-shadow: 2px 2px 10px #ccc;
    box-shadow: 2px 2px 10px #ccc;
}
.nav-search-fixed .navbar-header {
	display: none;
}
.navbar .nav-search-fixed .container .right_part {
	 100%;
}
.navbar .nav-search-fixed .container .right_part .ip-group {
	margin-left: 100px;
}
.nav-search-fixed .nav-btn {
	display: inline-block;
	position: relative;
    top: 2px;
}
...
...
...
.link-nav {
   100%;
  border-bottom: 2px solid #c90808;
  background: #fff;
  box-sizing: border-box;
  height: 72px;
  .container {
     1200px;
    margin: 0 auto;
    height: 72px;
    box-sizing: border-box;

    .navbar-nav {
       100%;
      height: 72px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-pack: distribute;
      justify-content: space-around;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      margin: 0;
      padding: 0;
      list-style: none;

      > li {
        float: left;
        position: relative;
        display: block;
        padding: 0;
        margin: 0;
        line-height: 72px;
        list-style-type: none;
        box-sizing: border-box;
       }
      }

      > .avatar-li {
        &:hover {
          .dropdown-menu {
            display: block;
          }
        }
       }
      }
    }
  }
  .container-fixed {
    position: fixed;
    z-index: 1000;
     1070px;
    top: 0;
    .navbar-nav {
      height: 120px;
    line-height: 120px;
    > li {
      line-height: 120px;
      &.active, &:hover {
        height: 120px;
      }
    }
    }
  }
  .clearfix {
    zoom: 1;
    display: block;
  }
}
.link-nav-fixed {
   1200px;
  margin: 0 auto;
}

JS

        $(function () {
            // 导航吸顶
            fixedNav();
            $(window).scroll(function () {
                fixedNav();
            })
        });
        // 页面滚动到一定高度,固定顶部导航
        var flag = false;
        function fixedNav() {
            var top = $(document).scrollTop();
            if (top >= 212) {
                $('.nav-search').addClass('nav-search-fixed');
                navChange();
            } else {
                $('.nav-search').removeClass('nav-search-fixed');
                $('.ip-group').show();
                $('.qrcodes').show();
                $('.container').removeClass('container-fixed');
                $('.link-nav').removeClass('link-nav-fixed');
            }
        };
        // 定位导航内容切换
        $('.nav-btn').click(function () {
            flag = !flag;
            navChange();
        });
        function navChange() {
            if (flag) {
                $('.nav-text').text("搜索");
                $('.nav-btn').children('.iconfont').removeClass('icon-other').addClass('icon-search');
                $('.ip-group').hide();
                $('.qrcodes').hide();
                $('.link-nav').addClass('link-nav-fixed');
                $('.container').addClass('container-fixed');
            } else {
                $('.nav-text').text("导航");
                $('.nav-btn').children('.iconfont').removeClass('icon-search').addClass('icon-other');
                $('.ip-group').show();
                $('.qrcodes').show();
                $('.link-nav').removeClass('link-nav-fixed');
                $('.container').removeClass('container-fixed');
            }
        }

总结

主要是scroll, scrollTop(), click, show(), hide方法和position: fixed等属性的理解和使用。需要注意的是,一开始就调用fixedNav(),是用于当页面刷新且未滚动,但页面已不在顶部的位置时(也就是刷新页面后看不到顶部导航的位置),出现吸顶的导航的效果。

原文地址:https://www.cnblogs.com/shellon/p/13366219.html