HTML/CSS

实现滚动时动态缩小导航栏jQuery效果

阿里云

我们先先看一下下面的效果,用 QQ 截的图,效果很不清楚,但是能说明问题。怎么实现这样的效果呢?用得比较多的算是 jQuery 的 waypoints 插件了,其实不用 jQuery 插件,很简单的一段 jQuery 代码就可以实现这样的效果,不过要结合 CSS3 过渡,IE9 以下的浏览器效果可能就差一点了。

实现以上效果的关键代码如下。首先,用 jQuery 判断网页滚动,网页滚动的高度大于 120 像素时,添加 “small” 类到 nav 上,其他情况下,移除这个类。这个和本站之前的文章添加返回顶部功能有点类似,都是基于 scrollTop 来判断的。

  1. $(document).on("scroll", function() {
  2.   if ($(document).scrollTop() > 120) {
  3.     $("nav").addClass("small");
  4.   } else {
  5.     $("nav").removeClass("small");
  6.   }
  7. });
也想出现在这里?联系我们
创客主机

然后,还需要 CSS 来配合,首先,顶部导航位置需要设为静态,然后导航变化时,加上 CSS3 过渡效果。

  1. nav {
  2.   height:141px;
  3.   background:#fff;
  4.   border-bottom:1px solid #ccc;
  5.   width:100%;
  6.   position:fixed;
  7.   top:0;
  8.   left:0;
  9.   z-index:10;
  10.   -webkit-transition:all .3s;
  11.   -moz-transition:all .3s;
  12.   transition:all .3s
  13. }
  14.  
  15. nav.small {
  16.   height: 51px;
  17. }

下拉网页,下拉的高度超过 120 像素时,导航就会像上面的效果那样自动缩小,非常简单,效果也非常不错。

实现滚动时动态缩小导航栏 jQuery 效果

已有 406 人购买
查看演示升级 VIP立刻购买

收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!