附加导航(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、基本实例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 | < 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 部分
1 2 3 4 5 6 7 8 9 10 11 12 13 | 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定位的。
1 2 3 4 5 6 7 8 9 10 11 12 | //设置成 bottom ul.nav-tabs.affix- bottom { bottom : 30px ; } //设置成 bottom $( '#myAffix' ).affix({ offset : { bottom : 150 } }) |
Affix 包含几个事件,如下:
1 2 3 4 5 | //其他雷同 $( '#myAffix' ).on( 'affixed-top.bs.affix' , function () { alert( '触发!' ); }); |
如果大家还想深入学习,可以点击这里进行学习,再为大家附3个精彩的专题:
以上就是本文的全部内容,希望对大家的学习有所帮助。
如对本文有疑问,请提交到交流社区,广大热心网友会为你解答!! 点击进入社区
联系客服