bootstrap——滚动监听组件
2018-03-31 15:57
330 查看
其实滚动监听使用的情况还是很多的,比如导航居于右侧,当主题内容滚动某一块的时候,右侧导航对应的要高亮。
2、导航必须是 .nav > li > a 结构,并且a上href或data-target要绑定hashkey
3、菜单上必须有.nav样式
4、滚动区域的data-target与导航父级Id(一定是父级)要一致。
data-target=".navbar-example" 绑定的导航总结:创建一个导航,设置一个标记class="navbar-example" ,与监听空间data-target=".navbar-example"进行绑定,让a找到里面的id,实现点击a跳到对应的id位置,其实就是锚点。添加监听滚动事件,当到达id的位置时,把class="active"转移到相应的a上,实现滚动到某一id,导航中相应的a发生改变。
转载自:https://www.cnblogs.com/moqiutao/p/6568073.html
实现功能
1、当滚动区域内设置的hashkey距离顶点到有效位置时,就关联设置其导航上的指定项2、导航必须是 .nav > li > a 结构,并且a上href或data-target要绑定hashkey
3、菜单上必须有.nav样式
4、滚动区域的data-target与导航父级Id(一定是父级)要一致。
<div id="selector" class="navbar navbar-default"> <ul class="nav navbar-nav"> <li><a href="#one">one</a> </li> <li><a href="#two">two</a> </li> <li><a href="#three">three</a> </li> </ul> </div> <div data-spy="scroll" data-target="#selector" style="height:100px; overflow:hidden;overflow-y: auto;" > <h4 id="one" >ibe</h4><p>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/></p> <h4 id="two" >two</h4><p>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/></p> <h4 id="three" >three</h4><p>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/>One的具体内容<br/></p> </div>下面来看一下实现的具体代码,原理:当滚动容器内的hashkey位置距离容器顶部只有 offset设置的值,就会设置导航中对应的href高亮。
ScrollSpy构造函数
首先新建一个构造函数,如下:function ScrollSpy(element, options) { this.$body = $(document.body) this.$scrollElement = $(element).is(document.body) ? $(window) : $(element) this.options = $.extend({}, ScrollSpy.DEFAULTS, options) this.selector = (this.options.target || '') + ' .nav li > a' this.offsets = [] this.targets = [] this.activeTarget = null this.scrollHeight = 0 this.$scrollElement.on('scroll.bs.scrollspy', $.proxy(this.process, this)) this.refresh() this.process() }该构造函数主要干了啥:1.基本设置,主要是设置当前滚动元素是设置的body还是具体的某一块元素;其次是导航的结构要是.nav li > a的结构,也就是你的菜单中也要有.nav这个class。2.监听元素滚动的时候,执行process方法。3.同时初始化的时候也执行了refresh与process方法。下面讲解一下这几个方法。
getScrolHeight方法
获取滚动容器的内容高度(包含被隐藏部分)this.$scrollElement[0].scrollHeight || Math.max(this.$body[0].scrollHeight, document.documentElement.scrollHeight)
refresh方法
刷新并存储滚动容器内各hashkey的值ScrollSpy.prototype.refresh = function () { var that = this var offsetMethod = 'offset' var offsetBase = 0 this.offsets = [] this.targets = [] this.scrollHeight = this.getScrollHeight() if (!$.isWindow(this.$scrollElement[0])) { offsetMethod = 'position' offsetBase = this.$scrollElement.scrollTop() } this.$body .find(this.selector) .map(function () { var $el = $(this) var href = $el.data('target') || $el.attr('href') var $href = /^#./.test(href) && $(href) return ($href && $href.length && $href.is(':visible') && [[$href[offsetMethod]().top + offsetBase, href]]) || null }) .sort(function (a, b) { return a[0] - b[0] }) .each(function () { that.offsets.push(this[0]) that.targets.push(this[1]) }) }它主要实现了什么呢?1.默认用offset来获取定位值,如果滚动区域不是window则用position来获取
if (!$.isWindow(this.$scrollElement[0])) { offsetMethod = 'position' offsetBase = this.$scrollElement.scrollTop() }2.根据导航上的hashkey来遍历获取 滚动区域内的hashkey对应的offset值:
this.$body .find(this.selector) .map(function () { var $el = $(this) var href = $el.data('target') || $el.attr('href') var $href = /^#./.test(href) && $(href) return ($href && $href.length && $href.is(':visible') && [[$href[offsetMethod]().top + offsetBase, href]]) || null }) .sort(function (a, b) { return a[0] - b[0] }) .each(function () { that.offsets.push(this[0]) that.targets.push(this[1]) })
process方法
滚动条事件触发函数,用于计算当前需要高亮那个导航菜单ScrollSpy.prototype.process = function () { var scrollTop = this.$scrollElement.scrollTop() + this.options.offset var scrollHeight = this.getScrollHeight() var maxScroll = this.options.offset + scrollHeight - this.$scrollElement.height() var offsets = this.offsets var targets = this.targets var activeTarget = this.activeTarget var i if (this.scrollHeight != scrollHeight) { this.refresh() } if (scrollTop >= maxScroll) { return activeTarget != (i = targets[targets.length - 1]) && this.activate(i) } if (activeTarget && scrollTop < offsets[0]) { this.activeTarget = null return this.clear() } for (i = offsets.length; i--;) { activeTarget != targets[i] && scrollTop >= offsets[i] && (offsets[i + 1] === undefined || scrollTop < offsets[i + 1]) && this.activate(targets[i]) } }主要作用:1.获取滚动容器已滚动距离:
var scrollTop = this.$scrollElement.scrollTop() + this.options.offset2.滚动容器可以滚动的最大高度:
var maxScroll = this.options.offset + scrollHeight - this.$scrollElement.height()3.设置滚动元素逻辑,给当前匹配元素添加高亮:
for (i = offsets.length; i--;) { activeTarget != targets[i] && scrollTop >= offsets[i] && (offsets[i + 1] === undefined || scrollTop < offsets[i + 1]) && this.activate(targets[i]) }
active方法
设置指定的导航菜单高亮ScrollSpy.prototype.activate = function (target) { this.activeTarget = target this.clear() var selector = this.selector + '[data-target="' + target + '"],' + this.selector + '[href="' + target + '"]' var active = $(selector) .parents('li') .addClass('active') if (active.parent('.dropdown-menu').length) { active = active .closest('li.dropdown') .addClass('active') } active.trigger('activate.bs.scrollspy') }
clear方法
清除所有高亮菜单ScrollSpy.prototype.clear = function () { $(this.selector) .parentsUntil(this.options.target, '.active') .removeClass('active') }总结data-spy="scroll":监听事件,滚动条
data-target=".navbar-example" 绑定的导航总结:创建一个导航,设置一个标记class="navbar-example" ,与监听空间data-target=".navbar-example"进行绑定,让a找到里面的id,实现点击a跳到对应的id位置,其实就是锚点。添加监听滚动事件,当到达id的位置时,把class="active"转移到相应的a上,实现滚动到某一id,导航中相应的a发生改变。
转载自:https://www.cnblogs.com/moqiutao/p/6568073.html
相关文章推荐
- Bootstrap滚动监听组件scrollspy.js使用方法详解
- bootstrap源码之滚动监听组件scrollspy.js详解
- bootstrap 的滚动监听
- 全面解析Bootstrap中scrollspy(滚动监听)的使用方法
- 响应式前端框架Bootstrap系列(17)滚动监听(Scrollspy)插件
- Bootstrap中的滚动监听
- Bootstrap滚动监听插件
- BootStrap下拉菜单和滚动监听插件实现代码
- Bootstrap响应式前端框架笔记十八——导航滚动监听
- bootstrap 3 navrbar实现置顶并滚动监听
- Bootstrap学习js插件篇之滚动监听
- bootstrap滚动监听插件Scrollspy横向和纵向实例对比
- bootstrap 滚动监听 标签页 和 工具提示
- Bootstrap每天必学之滚动监听
- bootstrap滚动监听
- Bootstrap滚动监听
- Bootstrap的js插件之滚动监听(scrollspy)
- Bootstrap插件(二)——滚动监听(scrollspy.js)
- bootstrap(下拉菜单与滚动监听)
- Bootstrap滚动监听(Scrollspy)插件详解