4.4Bootstrap学习js插件篇之滚动监听
2014-05-06 22:11
309 查看
1、滚动监听
滚动监听插件可以根据滚动条的位置自动更新所对应的导航标记。Bootstrap中文网左侧就是一个滚动监听的例子。
代码段:
预览:
通过为需要监听的页面元素(一般是
通过JavaScript启动滚动监听:
导航条内的链接地址必须有对应的页面元素具有同样的ID值。例如,
使用滚动监听插件时,每当页面中从DOM中增加或删除页面元素时,都需要调用此方法以,如下:
可以将选项通过data属性或JavaScript传递。对于data属性,需要将选项名称放到
案例
滚动监听插件可以根据滚动条的位置自动更新所对应的导航标记。Bootstrap中文网左侧就是一个滚动监听的例子。代码段:
<nav id="navbar-example2" class="navbar navbar-default navbar-static" role="navigation"> <div class="navbar-header"> <button class="navbar-toggle" type="button" data-toggle="collapse" data-target=".bs-js-navbar-scrollspy"> <span class="sr-only">Toggle-navigation</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button> <a href="#" class="navbar-brand">Project Name</a> </div> <div class="collapse navbar-collapse bs-js-navbar-scrollspy"> <ul class="nav navbar-nav"> <li><a href="#fat">@fat</a></li> <li><a href="#mdo">@mdo</a></li> <li class="dropdown"> <a href="#" id="navbarDrop1" class="dropdown-toggle" data-toggle="dropdown">Dropdown <b class="caret"></b></a> <ul class="dropdown-menu" role="menu" aria-labelledby="navbarDrop1"> <li><a href="#one" tabindex="-1">one</a></li> <li><a href="#two" tabindex="-1">two</a></li> <li class="divider"></li> <li><a href="#three" tabindex="-1">three</a></li> </ul> </li> </ul> </div> </nav>
<div class="scrollspy-example" data-target="#navbar-example2" data-offset="0" data-spy="scroll"> <h4 id="fat">@fat</h4> <p>Ad leggings keytar, brunch id art party dolor labore. Pitchfork yr enim lo-fi before they sold out qui. Tumblr farm-to-table bicycle rights whatever. Anim keffiyeh carles cardigan. Velit seitan mcsweeney's photo booth 3 wolf moon irure. Cosby sweater lomo jean shorts, williamsburg hoodie minim qui you probably haven't heard of them et cardigan trust fund culpa biodiesel wes anderson aesthetic. Nihil tattooed accusamus, cred irony biodiesel keffiyeh artisan ullamco consequat.</p> <h4 id="mdo">@mdo</h4> <p>Veniam marfa mustache skateboard, adipisicing fugiat velit pitchfork beard. Freegan beard aliqua cupidatat mcsweeney's vero. Cupidatat four loko nisi, ea helvetica nulla carles. Tattooed cosby sweater food truck, mcsweeney's quis non freegan vinyl. Lo-fi wes anderson +1 sartorial. Carles non aesthetic exercitation quis gentrify. Brooklyn adipisicing craft beer vice keytar deserunt.</p> <h4 id="one">one</h4> <p>Occaecat commodo aliqua delectus. Fap craft beer deserunt skateboard ea. Lomo bicycle rights adipisicing banh mi, velit ea sunt next level locavore single-origin coffee in magna veniam. High life id vinyl, echo park consequat quis aliquip banh mi pitchfork. Vero VHS est adipisicing. Consectetur nisi DIY minim messenger bag. Cred ex in, sustainable delectus consectetur fanny pack iphone.</p> <h4 id="two">two</h4> <p>In incididunt echo park, officia deserunt mcsweeney's proident master cleanse thundercats sapiente veniam. Excepteur VHS elit, proident shoreditch +1 biodiesel laborum craft beer. Single-origin coffee wayfarers irure four loko, cupidatat terry richardson master cleanse. Assumenda you probably haven't heard of them art party fanny pack, tattooed nulla cardigan tempor ad. Proident wolf nesciunt sartorial keffiyeh eu banh mi sustainable. Elit wolf voluptate, lo-fi ea portland before they sold out four loko. Locavore enim nostrud mlkshk brooklyn nesciunt.</p> <h4 id="three">three</h4> <p>Ad leggings keytar, brunch id art party dolor labore. Pitchfork yr enim lo-fi before they sold out qui. Tumblr farm-to-table bicycle rights whatever. Anim keffiyeh carles cardigan. Velit seitan mcsweeney's photo booth 3 wolf moon irure. Cosby sweater lomo jean shorts, williamsburg hoodie minim qui you probably haven't heard of them et cardigan trust fund culpa biodiesel wes anderson aesthetic. Nihil tattooed accusamus, cred irony biodiesel keffiyeh artisan ullamco consequat.</p> <p>Keytar twee blog, culpa messenger bag marfa whatever delectus food truck. Sapiente synth id assumenda. Locavore sed helvetica cliche irony, thundercats you probably haven't heard of them consequat hoodie gluten-free lo-fi fap aliquip. Labore elit placeat before they sold out, terry richardson proident brunch nesciunt quis cosby sweater pariatur keffiyeh ut helvetica artisan. Cardigan craft beer seitan readymade velit. VHS chambray laboris tempor veniam. Anim mollit minim commodo ullamco thundercats. </p> </div>
预览:
用法
通过data属性
通过为需要监听的页面元素(一般是<body>)添加
data-spy="scroll"就可很轻松的为顶部导航条添加滚动监听功能。然后为其添加
data-target属性,此属性的值为任何Bootstrap中
.nav组件的父元素的ID或class。
<body data-spy="scroll" data-target=".navbar-example"> ... <div class="navbar-example"> <ul class="nav nav-tabs"> ... </ul> </div> ... </body>
通过JavaScript
通过JavaScript启动滚动监听:$('body').scrollspy({ target: '.navbar-example' })
导航链接地址必须有对应的目标
导航条内的链接地址必须有对应的页面元素具有同样的ID值。例如,<a href="#home">home</a>必须对应DOM中例如
<div id="home"></div>。
方法
.scrollspy('refresh')
使用滚动监听插件时,每当页面中从DOM中增加或删除页面元素时,都需要调用此方法以,如下:$('[data-spy="scroll"]').each(function () { var $spy = $(this).scrollspy('refresh') })
选项
可以将选项通过data属性或JavaScript传递。对于data属性,需要将选项名称放到data-之后,例如
data-offset=""。
名称 | 类型 | 默认值 | 描述 |
---|---|---|---|
offset | number | 10 | Pixels to offset from top when calculating position of scroll. |
事件
事件类型 | 描述 |
---|---|
activate.bs.scrollspy | 当滚动监听插件将某个元素置为active时,此事件被触发。 |
$('#myScrollspy').on('activate.bs.scrollspy', function () { // do something… })
相关文章推荐
- Bootstrap学习js插件篇之滚动监听
- 学习Bootstrap滚动监听 附调用方法
- bootstrap学习32---滚动监听scrollspy.js
- Bootstrap3.0学习第二十轮(JavaScript插件——滚动监听)
- 【学习笔记】Bootstrap插件 滚动监听+弹出框+选项卡
- Bootstrap3.0学习第二十轮(JavaScript插件——滚动监听)
- Bootstrap教程JS插件滚动监听学习笔记分享
- Bootstrap教程JS插件滚动监听学习笔记分享
- Bootstrap3.0学习第二十轮(JavaScript插件——滚动监听)
- flex学习笔记 在任意地方监听事件
- 学习笔记--cocos2dx-3.0中LabelTTF添加触摸监听事件
- android学习10#--基于监听的事件处理
- JS实现滚动监听以及滑动到顶部
- Cocos2d-x学习(十二):用cocos2d-x实现MoonWarriors(无限背景滚动的简单实现)
- Bootstrap滚动监听插件
- (9) ebj学习: Jpa的增删查改,CURD方法监听和命名查询
- Java语言学习--Swing中Button事件监听
- Bootstrap 下拉菜单和滚动监听(Scrollspy)插件
- Android对ScrollView滚动监听,实现美团、大众点评的购买悬浮效果
- jQuery滚动监听,实现商城楼梯式导航、滚动监听根据滚动条所处的位置来自动更新导航项