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


Posted in Javascript onApril 25, 2016

附加导航(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 来传递的。下表列出了这些选项:

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

四、实例
附加导航即粘贴在屏幕某处实现锚点功能。
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 包含几个事件,如下:

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

//其他雷同

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

如果大家还想深入学习,可以点击这里进行学习,再为大家附3个精彩的专题:

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

Javascript 相关文章推荐
js tab 选项卡
Apr 26 Javascript
利用onresize使得div可以随着屏幕大小而自适应的代码
Jan 15 Javascript
Javascript处理DOM元素事件实现代码
May 23 Javascript
javascript:json数据的页面绑定示例代码
Jan 26 Javascript
js中定义一个变量并判断其是否为空的方法
May 13 Javascript
13个PHP函数超实用
Oct 21 Javascript
第一次接触神奇的Bootstrap网格系统
Jul 27 Javascript
angularJS Provider、factory、service详解及实例代码
Sep 21 Javascript
CSS+jQuery实现简单的折叠菜单
Dec 20 Javascript
js自定义QQ菜单效果
Jan 10 Javascript
利用Javascript裁剪图片并存储的简单实现
Mar 13 Javascript
js中的DOM模拟购物车功能
Mar 22 Javascript
Bootstrap项目实战之子栏目资讯内容
Apr 25 #Javascript
深入浅析JavaScript中数据共享和数据传递
Apr 25 #Javascript
Bootstrap项目实战之首页内容介绍(全)
Apr 25 #Javascript
Bootstrap每天必学之响应式导航、轮播图
Apr 25 #Javascript
Java遍历集合方法分析(实现原理、算法性能、适用场合)
Apr 25 #Javascript
下雪了 javascript实现雪花飞舞
Aug 02 #Javascript
基于node实现websocket协议
Apr 25 #Javascript
You might like
PHP中的类型提示(type hinting)功能介绍
2015/07/01 PHP
PHP实现操作redis的封装类完整实例
2015/11/14 PHP
PHP递归实现文件夹的复制、删除、查看大小操作示例
2017/08/11 PHP
PHP实现双链表删除与插入节点的方法示例
2017/11/11 PHP
getJSON调用后台json数据时函数被调用两次的原因猜想
2013/09/29 Javascript
javaScript对文字按照拼音排序实现代码
2013/12/27 Javascript
js将控件隐藏及display属性的使用介绍
2013/12/30 Javascript
JSONP获取Twitter和Facebook文章数的具体步骤
2014/02/24 Javascript
JavaScript动态创建link标签到head里的方法
2014/12/22 Javascript
JavaScript学习笔记之数组求和方法
2016/03/23 Javascript
nodejs个人博客开发第一步 准备工作
2017/04/12 NodeJs
JS传参及动态修改页面布局
2017/04/13 Javascript
vue2 前后端分离项目ajax跨域session问题解决方法
2017/04/27 Javascript
Angular 表单控件示例代码
2017/06/26 Javascript
JavaScript登录验证基础教程
2017/11/01 Javascript
浅谈webpack打包过程中因为图片的路径导致的问题
2018/02/21 Javascript
Vue 莹石摄像头直播视频实例代码
2018/08/31 Javascript
JS实现简单的点赞与踩功能示例
2018/12/05 Javascript
通过cordova将vue项目打包为webapp的方法
2019/02/02 Javascript
微信小程序开发实现的选项卡(窗口顶部/底部TabBar)页面切换功能图文详解
2019/05/14 Javascript
nodejs中各种加密算法的实现详解
2019/07/11 NodeJs
原生js+canvas实现验证码
2020/11/29 Javascript
[06:50]DSPL次级职业联赛十强晋级之路
2014/11/18 DOTA
[04:44]DOTA2西游记战队视频彩蛋流出 师徒开黑巧遇林书豪
2016/08/03 DOTA
Python-while 计算100以内奇数和的方法
2019/06/11 Python
Python循环结构的应用场景详解
2019/07/11 Python
python PyQt5/Pyside2 按钮右击菜单实例代码
2019/08/17 Python
Python生成器实现简单&quot;生产者消费者&quot;模型代码实例
2020/03/27 Python
通过python 执行 nohup 不生效的解决
2020/04/16 Python
canvas基础之图形验证码的示例
2018/01/02 HTML / CSS
weblogic面试题
2016/03/07 面试题
NULL是什么,它是怎么定义的
2015/05/09 面试题
什么叫应用程序域?什么是托管代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别作何解释?
2012/05/23 面试题
村捐赠仪式答谢词
2014/01/21 职场文书
我的大学四年规划书范文2014
2014/09/26 职场文书
详解PHP Swoole与TCP三次握手
2021/05/27 PHP