欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

如何使用封装实现楼层点亮效果(代码实例)

程序员文章站 2022-03-25 10:30:08
...
本章给大家介绍如何使用封装实现楼层点亮效果(代码实例)。有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

功能需求:

1.鼠标滚动到页面内容楼层时,侧边导航楼层出现;否则隐藏。

2.鼠标滚动到相应楼层时,侧边导航楼层高亮。

3.点击侧边导航时,页面滚动到相应楼层。

如下图:

如何使用封装实现楼层点亮效果(代码实例)

技术要点:

1. 熟练使用jquery、js,

2. 动画 ;scrollTop( ) ; offset( ). top

3. 锚点的应用

实现过程:

1. 封装一个楼层滚动点亮的插件,在主页面程序中调用此方法

如何使用封装实现楼层点亮效果(代码实例)

2.接下来我们深入到插件内部,实现插件的具体功能。

  1. scrollsoy(options){ 功能 },这里我们给插件传递了一个参数,如上图函数中传入了一个对象{target:“div.affix”},即我们侧边附加导航的class。如此以来好处是提高代码的复用性,今后只要需要这样的功能,我们只需要修改target的值即可,这就是插件。

  2. 在插件内定义一个滚动事件,进行楼层开关的点亮。

    i)、获取window距离滚动条顶部滚动的距离,var top = $(window).scrollTop();

    ii)、判断:

    如果现在滚动在1楼上方(top<1F的距离),做侧边附加导航栏的淡出效果;

    如果现在滚动在3楼下方(top>3F的距离),做侧边附加导航栏的淡出效果;

    else,现在1楼和3楼之间,做侧边附加导航栏的淡入效果;此时,点亮当前滚动的楼层开关

    遍历侧边附加导航栏每个楼层,查看window滚动偏移量超过页面哪个楼层的偏移量
    如何获取页面楼层的偏移量?如上图侧边附加导航栏a标签的href属性与页面楼层id绑定,通过a标签的href属性获取它 在页面的锚点,再使用offset(). top即可取得页面楼层的偏移量
    判断——top>页面楼层的偏移量,说明窗口已经滚动到特定的楼层。给侧边附加导航栏楼层高亮

  3. 在插件内定义一个点击事件,点击侧边附加导航栏,页面滚动到相应楼层

    首先,阻止超链接的默认行为

    根据a的href属性,找到其对应的楼层的距离页面顶部的偏移量

    使用动画效果,让页面主体滚动到指定的高度。注意此处高亮部分有兼容性问题$('body').animate({scrollTop: 偏移量}, 500)

总结:

相信大家在看过这个实例之后对封装有了更好的理解,今后在实现功能的时候我们都可以带着这样的眼光去思考问题,以此来提高代码的复用性。不过假如能亲自动手试一试,尝一下实际遇到的困难才能发现自己的问题不断的提高自己的能力。

以上就是如何使用封装实现楼层点亮效果(代码实例)的详细内容,更多请关注其它相关文章!