深入浅析Bootstrap中的自动定位浮标

 4728

本篇文章带大家详细了解一下Bootstrap中的自动定位浮标。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。


深入浅析Bootstrap中的自动定位浮标


Affix 插件主要功能就是通过插件给某个元素(需要固定的元素)添加或删除position:fixed,实现元素在浏览器窗口的粘性固定效果。


基本用法

首先,来看一个苹果官网对自动定位浮标的应用


深入浅析Bootstrap中的自动定位浮标


从上面的git图中可知,Macbook一栏滚动到一定高度时,固定在窗口顶部便不再移动

Affix 插件可以对任何元素进行固定定位,其中比较简单的方法,就是通过自定义属性data来触发。其主要包括两个参数:

1、data-spy:取值 affix,表示元素是固定不变的。

2、data-offset:整数值,比如 90,表示元素 top 和 bottom 的值都是 90px,其包括两种方式:data-offset-top和data-offset-bottom

data-offset-top用来设置元素距离顶部的距离。比如 90,表示元素距离顶部 90px,当用户从顶部向下拖动滚动条,当滚动的距离大于 90px 时,affix 元素不再滚动,就会固定在浏览器窗口顶部

data-offset-bottom刚好与 data-offset-top 相反

  1. <div data-spy="affix" data-offset="90">affix元素</div>
  2. <!-- 等价 -->
  3. <div data-spy="affix" data-offset-top="90" data-offset-bottom="90">affix元素</div>

【设置CSS】

在使用Affix插件时,必须通过 CSS 定位内容。Affix插件在三种 class 之间切换,每种 class 都呈现了特定的状态:.affix、.affix-top 和 .affix-bottom

1、在开始时,插件添加.affix-top来指示元素在它的最顶端位置。这个时候不需要任何的 CSS 定位 

2、当滚动经过添加了Affix的元素时,应触发实际的Affix。此时.affix会替代.affix-top,同时设置position: fixed(由 Bootstrap 的 CSS 代码提供)

这时,需要手动设置.affix,如.affix{top:0;}表示停止在窗口顶部

3、如果定义了底部偏移,当滚动到达该位置时,应把.affix替换为.affix-bottom。由于偏移是可选的,假如设置了该偏移,则要求同时设置适当的 CSS。在这种情况下,请在必要的时候添加position: absolute;

  1. <style>
  2. .test{width: 100%;height: 50px;background-color:lightgreen;}
  3. .affix{top:0px;}
  4. </style>
  5. </head>
  6. <body style="height:1000px;" >
  7.     <div style="height:100px"></div>
  8.     <div data-spy="affix" data-offset="100" class="test"></div>
  9. </body>


深入浅析Bootstrap中的自动定位浮标


JS触发

有时候,使用该插件,其顶部和底部的高度不一定是固定的,所以在初始化时使用声明式用法不太合适。这时,使用javascript用法就显得比较灵活了,因为它不仅支持传入数字型的offset,还支持传入能够动态计算offset的function函数

  1. <script>
  2. $('#myAffix').affix({
  3.     offset: {
  4.         top:100,
  5.         bottom: function () {
  6.             return (this.bottom = $('footer').outerHeight(true))
  7.         }
  8.     }
  9. })    
  10. </script>

【事件】

affix组件提供了6种事件,即affix和affixed各对应于3种状态(普通、top、bottom)时的事件

  1. affix.bs.affix    在定位结束之前立即触发
  2. affixed.bs.affix    在定位结束之后立即触发
  3. affix-top.bs.affix    在定位元素应用affixed-top效果之前立即触发
  4. affixed-top.bs.affix    在定位元素应用affixed-top效果之后立即触发
  5. affix-bottom.bs.affix    在定位元素应用affixed-bottom效果之前立即触发
  6. affixed-bottom.bs.affix    在定位元素应用affixed-bottom效果之后立即触发
  1. <style>
  2. .test{width: 100%;height: 50px;background-color:lightgreen;}
  3. header{height: 100px;}
  4. .affix{top:0px;}
  5. </style>
  6. </head>
  7. <body style="height:1000px;">
  8. <header></header>
  9. <div data-spy="affix" class="test"></div>
  10. <script>
  11. $(function(){
  12.     $('.test').affix({
  13.         offset:{
  14.             top:function(){
  15.                 return (this.top = $('header').outerHeight(true))
  16.             }
  17.         }
  18.     }).on('affix.bs.affix',function(){
  19.         $(this).html('我被固定在窗口顶部');
  20.     }).on('affix-top.bs.affix',function(){
  21.         $(this).html('我正跟随滚动条滚动');
  22.     })
  23. })    
  24. </script>


深入浅析Bootstrap中的自动定位浮标


TAG标签:
本文网址:https://www.zztuku.com/detail-8828.html
站长图库 - 深入浅析Bootstrap中的自动定位浮标
申明:如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐

    js实现简单图片拖拽效果