zoukankan      html  css  js  c++  java
  • 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(),是用于当页面刷新且未滚动,但页面已不在顶部的位置时(也就是刷新页面后看不到顶部导航的位置),出现吸顶的导航的效果。

  • 相关阅读:
    nginx简单配置
    解决 eclipse出现 Address already in use: bind
    JavaScript 正则表达式学习
    RabbitMQ的介绍与spring整合
    RabbitMQ的安装与客户端的简单实用
    java中的break与continue
    书单
    (七)SpringBoot2.0基础篇- application.properties属性文件的解析及获取
    (六)SpringBoot2.0基础篇- MyBatis、Redis整合(JedisCluster集群连接)
    (五)SpringBoot2.0基础篇- Mybatis与插件生成代码
  • 原文地址:https://www.cnblogs.com/shellon/p/13366219.html
Copyright © 2011-2022 走看看