前面的话

  Affix 插件主要功能就是通过插件给某个元素(需要固定的元素)添加或删除position:fixed,实现元素在浏览器窗口的粘性固定效果。本文将详细介绍Bootstrap自动定位浮标

基本用法

  首先,来看一个苹果官网对自动定位浮标的应用

  从上面的git图中可知,Macbook一栏滚动到一定高度时,固定在窗口顶部便不再移动

  Affix 插件可以对任何元素进行固定定位,其中比较简单的方法,就是通过自定义属性 data 来触发。其主要包括两个参数:

  1、data-spy:取值 affix,表示元素是固定不变的。

  2、data-offset:整数值,比如 90,表示元素 top 和 bottom 的值都是 90px,其包括两种方式:data-offset-top 和 data-offset-bottom

  data-offset-top 用来设置元素距离顶部的距离。比如 90,表示元素距离顶部 90px,当用户从顶部向下拖动滚动条,当滚动的距离大于 90px 时,affix 元素不再滚动,就会固定在浏览器窗口顶部

  data-offset-bottom 刚好与 data-offset-top 相反

<div data-spy="affix" data-offset="90">affix元素</div>
<!-- 等价 -->
<div data-spy="affix" data-offset-top="90" data-offset-bottom="90">affix元素</div>

【设置CSS】

  在使用Affix插件时,必须通过 CSS 定位内容。Affix插件在三种 class 之间切换,每种 class 都呈现了特定的状态: .affix、.affix-top 和 .affix-bottom

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

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

  这时,需要手动设置.affix,如.affix{top:0;}表示停止在窗口顶部

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

<style>
.test{width: 100%;height: 50px;background-color:lightgreen;}
.affix{top:0px;}
</style>
</head>
<body style="height:1000px;" >
<div style="height:100px"></div>
<div data-spy="affix" data-offset="100" class="test"></div>
</body>

JS触发

  有时候,使用该插件,其顶部和底部的高度不一定是固定的,所以在初始化时使用声明式用法不太合适。这时,使用javascript用法就显得比较灵活了,因为它不仅支持传入数字型的offset,还支持传入能够动态计算offset的function函数

<script>
$('#myAffix').affix({
offset: {
top:100,
bottom: function () {
return (this.bottom = $('footer').outerHeight(true))
}
}
})
</script>

【事件】

  affix组件提供了6种事件,即affix和affixed各对应于3种状态(普通、top、bottom)时的事件

affix.bs.affix    在定位结束之前立即触发
affixed.bs.affix 在定位结束之后立即触发
affix-top.bs.affix 在定位元素应用affixed-top效果之前立即触发
affixed-top.bs.affix 在定位元素应用affixed-top效果之后立即触发
affix-bottom.bs.affix 在定位元素应用affixed-bottom效果之前立即触发
affixed-bottom.bs.affix 在定位元素应用affixed-bottom效果之后立即触发
<style>
.test{width: 100%;height: 50px;background-color:lightgreen;}
header{height: 100px;}
.affix{top:0px;}
</style>
</head>
<body style="height:1000px;">
<header></header>
<div data-spy="affix" class="test"></div>
<script>
$(function(){
$('.test').affix({
offset:{
top:function(){
return (this.top = $('header').outerHeight(true))
}
}
}).on('affix.bs.affix',function(){
$(this).html('我被固定在窗口顶部');
}).on('affix-top.bs.affix',function(){
$(this).html('我正跟随滚动条滚动');
})
})
</script>

最新文章

  1. js按键监听
  2. angular2 - content projection-
  3. PlateSpin 完全复制由于LVM没有可用空闲空间导致失败
  4. 怎么修改git提交过的内容
  5. java实现读取文件大全
  6. C# 动态绘制任务栏图标的实现
  7. javascript禁用与启用select标签(实用版)
  8. HTML常用字符
  9. HTML静态网页(框架)
  10. Install Linux Kernel - AT91SAM9260EK
  11. Linux目录结构示意详解图
  12. 语音激活检测(VAD)--前向神经网络方法(Alex)
  13. Android - &quot;cause failed to find target android-14&quot; 问题
  14. centos7搭建postfix邮件服务器
  15. Resharper使用详解(转)
  16. QQ空间、新浪微博、腾讯微博等一键分享API链接代码
  17. python中从键盘输入内容的方法raw_input()和input()的区别
  18. Java设计模式之单例模式(七种写法)
  19. VNC的安装和常用命令
  20. npm install 后缀

热门文章

  1. ubuntu下修改网卡名称
  2. java语言基础1问题汇总
  3. 通过socket获取图片并保存
  4. BZOJ4911: [Sdoi2017]切树游戏
  5. UOJ224 NOI2016 旷野大计算 构造、造计算机
  6. 读取Excel的记录并导入SQL数据库
  7. (转)Linux SSH配置和禁止Root远程登陆设置
  8. HTML 图片轮播制作工具
  9. CYJian的水题大赛
  10. [Spark][Hive]Hive的命令行客户端启动: