Bootstrap 附加导航(Affix)插件

前言 🔗

  • 附加导航(Affix)插件允许指定 <div> 固定在页面的某个位置。一个常见的例子是社交图标。它们将在某个位置开始,但当页面点击某个标记,该 <div> 会锁定在某个位置,不会随着页面其他部分一起滚动。

  • 如果想要单独引用该插件的功能,那么需要引用 affix.js。或者,正如 Bootstrap 插件概览 一章中所提到,可以引用 bootstrap.js 或压缩版的 bootstrap.min.js。

1、用法

  • 可以通过 data 属性或者通过 JavaScript 来使用附加导航(Affix)插件。

    • 通过 data 属性:如需向元素添加附加导航(Affix)行为,只需要向需要监听的元素添加 data-spy="affix" 即可。请使用偏移来定义何时切换元素的锁定和移动。

    • 通过 JavaScript:您可以通过 JavaScript 手动为某个元素添加附加导航(Affix),如下所示:

      1
      2
      3
      4
      5
      6
      7
      8
      $('#myAffix').affix({
      offset: {
      top: 100, bottom: function () {
      return (this.bottom =
      $('.bs-footer').outerHeight(true))
      }
      }
      })
  • 实例

  • 效果

2、通过 CSS 定位

  • 在上面两种使用附加导航(Affix)插件的方式中,都必须通过 CSS 定位内容。附加导航(Affix)插件在三种 class 之间切换,每种 class 都呈现了特定的状态:.affix.affix-top.affix-bottom。请按照下面的步骤,来为这三种状态设置您自己的 CSS(不依赖此插件)。

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

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

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

3、选项

  • 有一些选项是通过 data 属性或 JavaScript 来传递的。下表列出了这些选项:
选项名称 类型/默认值 Data 属性名称 描述
offset number | function | object
默认值:10
data-offset 当计算滚动位置时,距离顶部的偏移像素。如果设置了一个数字,则该偏移量的值将被应用在顶部和底部。
如果设置了一个对象偏移,则其值形如 offset: { top: 10 }offset: { top: 10, bottom: 5 }
如果需要动态计算偏移,请使用函数

4、Bootstrap 布局组件 导航栏

文章目录
  1. 1. 前言 🔗
  2. 2. 1、用法
  3. 3. 2、通过 CSS 定位
  4. 4. 3、选项
  5. 5. 4、Bootstrap 布局组件 导航栏
隐藏目录