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代码
Mar 26 Javascript
js控制iframe的高度/宽度让其自适应内容
Apr 09 Javascript
JavaScript如何调试有哪些建议和技巧附五款有用的调试工具
Oct 28 Javascript
jQuery 遍历map()方法详解
Nov 04 Javascript
从零开始学习Node.js系列教程二:文本提交与显示方法
Apr 13 Javascript
JS监控关闭浏览器操作的实例详解
Sep 12 Javascript
BootstrapTable加载按钮功能实例代码详解
Sep 22 Javascript
实例分析js事件循环机制
Dec 13 Javascript
js统计页面上每个标签的数量实例代码
May 29 Javascript
vue 弹框产生的滚动穿透问题的解决
Sep 21 Javascript
深入学习JavaScript中的bom
May 27 Javascript
如何搭建一个完整的Vue3.0+ts的项目步骤
Oct 18 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过滤危险html代码
2008/08/18 PHP
php中url传递中文字符,特殊危险字符的解决方法
2013/08/17 PHP
php实现SAE上使用storage上传与下载文件的方法
2015/06/29 PHP
WordPres对前端页面调试时的两个PHP函数使用小技巧
2015/12/22 PHP
JSON字符串传到后台PHP处理问题的解决方法
2016/06/05 PHP
PHP面向对象程序设计子类扩展父类(子类重新载入父类)操作详解
2019/06/14 PHP
JsDom 编程小结
2011/08/09 Javascript
JavaScript 模拟类机制及私有变量的方法及思路
2013/07/10 Javascript
jQuery中:first-child选择器用法实例
2014/12/31 Javascript
AngularJS基础知识笔记之表格
2015/05/10 Javascript
jQuery解析XML文件同时动态增加js文件的方法
2015/06/01 Javascript
bootstrap下拉列表与输入框组结合的样式调整
2016/10/08 Javascript
微信小程序 教程之注册页面
2016/10/17 Javascript
Bootstrap 3.x打印预览背景色与文字显示异常的解决
2016/11/06 Javascript
prototype与__proto__区别详细介绍
2017/01/09 Javascript
微信公众号菜单配置微信小程序实例详解
2017/03/31 Javascript
vue中配置mint-ui报css错误问题的解决方法
2017/10/11 Javascript
Vue实现点击时间获取时间段查询功能
2020/08/21 Javascript
基于Vue的延迟加载插件vue-view-lazy
2018/05/21 Javascript
Vue实现搜索结果高亮显示关键字
2019/05/28 Javascript
CKeditor富文本编辑器使用技巧之添加自定义插件的方法
2019/06/14 Javascript
微信小程序实现点击空白隐藏的方法示例
2019/08/13 Javascript
vue项目中使用多选框的实例代码
2020/07/22 Javascript
Vue中watch、computed、updated三者的区别及用法
2020/07/27 Javascript
[02:51]DOTA2英雄基础教程 艾欧
2014/01/13 DOTA
python中使用OpenCV进行人脸检测的例子
2014/04/18 Python
Django后台获取前端post上传的文件方法
2018/05/28 Python
对tf.reduce_sum tensorflow维度上的操作详解
2018/07/26 Python
opencv实现图像几何变换
2021/03/24 Python
招商业务员岗位职责
2013/12/16 职场文书
销售总经理岗位职责
2014/03/15 职场文书
岗位说明书标准范本
2014/07/30 职场文书
4s店活动策划方案
2014/08/25 职场文书
初婚未育证明样本
2015/06/18 职场文书
感恩教育主题班会
2015/08/12 职场文书
高三化学教学反思
2016/02/22 职场文书