Bootstrap每天必学之附加导航(Affix)插件

前端技术 2023/09/02 JavaScript

附加导航(Affix)插件允许某个 <div> 固定在页面的某个位置。您也可以在打开或关闭使用该插件之间进行切换。一个常见的例子是社交图标。它们将在某个位置开始,但当页面点击某个标记,该 <div> 会锁定在某个位置,不会随着页面其他部分一起滚动。
如果您想要单独引用该插件的功能,那么您需要引用 affix.js。

一、用法

可以通过 data 属性或者通过 JavaScript 来使用附加导航(Affix)插件。
1、通过 data 属性:如需向元素添加附加导航(Affix)行为,只需要向需要监听的元素添加 data-spy=\"affix\" 即可。请使用偏移来定义何时切换元素的锁定和移动。
2、通过 JavaScript:您可以通过 JavaScript 手动为某个元素添加附加导航(Affix)

二、通过 CSS 定位

在上面两种使用附加导航(Affix)插件的方式中,您都必须通过 CSS 定位内容。附加导航(Affix)插件在三种 class 之间切换,每种 class 都呈现了特定的状态: .affix、.affix-top 和 .affix-bottom。请按照下面的步骤,来为这三种状态设置您自己的 CSS(不依赖此插件)。
1、在开始时,插件添加 .affix-top 来指示元素在它的最顶端位置。这个时候不需要任何的 CSS 定位。
2、当滚动经过添加了附加导航(Affix)的元素时,应触发实际的附加导航(Affix)。此时 .affix 会替代 .affix-top,同时设置 position: fixed;(由 Bootstrap 的 CSS 代码提供)。
3、如果定义了底部偏移,当滚动到达该位置时,应把 .affix 替换为 .affix-bottom。由于偏移是可选的,假如设置了该偏移,则要求同时设置适当的 CSS。在这种情况下,请在必要的时候添加 position: absolute;。

三、选项

有一些选项是通过 data 属性或 JavaScript 来传递的。下表列出了这些选项:

四、实例
附加导航即粘贴在屏幕某处实现锚点功能。
1、基本实例

<body data-spy=\"scroll\" data-target=\"#myScrollspy\">

 <div class=\"container\">
 <div class=\"jumbotron\" style=\"height:150px\">
  <h1>Bootstrap Affix</h1>
 </div>
 <div class=\"row\">
  <div class=\"col-xs-3\" id=\"myScrollspy\">
  <ul class=\"nav nav-pills nav-stacked\" data-spy=\"affix\"data-offset-top=\"150\">
   <li class=\"active\">
   <a href=\"#section-1\">第一部分 </a>
   </li>
   <li>
   <a href=\"#section-2\">第二部分</a>
   </li>
   <li>
   <a href=\"#section-3\">第三部分</a>
   </li>
   <li>
   <a href=\"#section-4\">第四部分</a>
   </li>
   <li>
   <a href=\"#section-4\">第五部分</a>
   </li>
  </ul>
  </div>
  <div class=\"col-xs-9\">
  <h2 id=\"section-1\">第一部分</h2>
  <p>
   ...
  </p>
  <h2 id=\"section-2\">第二部分</h2>
  <p>
   ...
  </p>
  <h2 id=\"section-3\">第三部分</h2>
  <p>
   ...
  </p>
  <h2 id=\"section-4\">第四部分</h2>
  <p>
   ...
  </p>
  <h2 id=\"section-5\">第四部分</h2>
  <p>
   ...
  </p>
  </div>

 </div>
 </div>

2、导航的 CSS 部分

ul.nav-pills {
 width: 200px;
}
ul.nav-pills.affix {
 top: 30px;
}
//JavaScript 代替 data-spy=\"affix\" data-offset-top=\"125\"

$(\'#myAffix\').affix({
 offset : {
 top : 150
 }
})

我们默认使用的是 top,当然也可以默认居底 bottom。这个定位方式是直接通过 CSS定位的。

//设置成 bottom

ul.nav-tabs.affix-bottom {
 bottom: 30px;
}
//设置成 bottom

$(\'#myAffix\').affix({
 offset : {
 bottom : 150
 }
})

Affix 包含几个事件,如下:

//其他雷同

$(\'#myAffix\').on(\'affixed-top.bs.affix\', function() {
 alert(\'触发!\');
});

更多内容可以参考:Bootstrap学习教程

以上就是本文的全部内容,希望对大家的学习有所帮助。 

本文地址:https://www.stayed.cn/item/4926

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。