bootstrap滚动监控器使用方法解析

1、当用户鼠标滚动时,滚动条的位置会自动更新导航条中相应的导航项。
这是因为该插件可以自动检测滚动条到达哪个位置,然后在需要高亮的菜单元素上加了一个“active”样式。

滚动监控器–滚动监控器的设计

第一步:使用滚动监控器,首要的条件是在页面中加载对应的插件。在这里你可以加载合并好的bootstrap.js或者其独立的插件文件scrollspy.js。这里以加载合并好的js为例:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>

第二步:设计一个带有下拉菜单的导航条。分别为导航条和下拉菜单项定义一个锚点链接,锚点分别为“#blog”,“html”,“#css”,“#sass”,“#js”,“php”,“#about”。同时为导航条定义一个id值“navbar-menu”(id名称可自由定义),方便滚动监控。

bootstrap滚动监控器使用方法解析

第三步:设计监控对象。这里将监控对象内容都放置在一个div名为scrollspy(这个类名可自由定义)的容器中,其中放了多个子内容框。每个子内容框有一个标题,而且每个标题的ID值与导航菜单项中的锚点链接名相对应,并且注意加入“data-target=”#navbar-menu””属性(这个属性值要与前面的nav标签的id名称保持一致)

<div data-target="#navbar-menu"> <h4>Blog</h4> <p>…</p> <h4>Html</h4> <p>…</p> <h4>CSS</h4> <p>…</p> <h4>Sass</h4> <p>…</p> <h4>JavaScript</h4> <p>…</p> <p>…</p> <h4>PHP</h4> <p>…</p> <p>…</p> <h4>About</h4> <p>…</p> <p>…</p> </div>

第四步:为监控对象定义样式,设置容器scrollspy大小(设置高度目的是为了产生垂直滚动条)。

.scrollspy{ height:500px; font-size:20px; overflow:auto; }

滚动监控器–声明属性触发滚动监控

为监控对象设置被监控的data属性:data-spy=”scroll”,指定监控的导航条:data-target=”#navbar-menu”。同时定义监控过程中滚动条偏移位置data-offset=”60”。代码如下:

<div data-spy="scroll" data-target="#navbar-menu" data-offset="60"> … </div>

滚动监控器–在body中加监控
还可以直接在body上进行滚动条监控,此时要将滚动监控器移到body上,而且导航nav一定要在body内部。

<body data-spy="scroll" data-target="#navbar-menu"> <div> </div> <h3>Blog</h3> <p>…</p> </body>

导航条必须设置为顶部固定样式(navbar-fixed-top)

滚动监控器–JavaScript方法触发滚动监控器

在Bootstrap框架中,使用JavaScript方法触发滚动监控器相对来说较为简单,只需要指定两个容器的名称即可

<nav role="navigation"> … </nav> <div> … </div>

JavaScript触发可以这样写:

$(function(){ $("#scrollspy").scrollspy({ target: "#navbar-menu" }); })

Bootstrap的滚动监控还提供了一个方法scrollspy(“refresh”)。当滚动监控所作用的DOM有增加或删除页面元素的操作时,需要调用下面的refresh方法:

$(function(){ $("[data-spy='scroll']").each(function(){ var $spy=$(this).scrollspy("refresh"); }) })

注意的是,这种refresh方法只对声明式用法有效。另外滚动监控除了options参数“target”之外,还提供了一个offset参数,此参数默认值为10。默认情况下,滚动内容距离滚动容器10px以内的话,就高一片面前显示所对应的菜单项。

滚动监实例 :

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css"> <style> .scrollspy-example{ height:500px; font-size:20px; overflow:auto; } </style> </head> <body> <div> <div> <!----导航容器--> <nav role="navigation"> <div> <div> <!----点击这个按钮时,触发bs-example-js-navbar-scrollspy: 这个css类,也就是下拉列表--> <button data-target=".bs-example-js-navbar-scrollspy" data-toggle="collapse" type="button"> <span></span> <span></span> <span></span> </button> <!----导航标题--> <a href="#">导航标题</a> </div> <!----折叠菜单容器--> <div> <!----导航--> <ul> <li><a href="#fat">@fat</a></li> <li><a href="#mdo">@mdo</a></li> <li> <a aria-expanded="false" role="button" data-toggle="dropdown" href="#">Dropdown <span></span></a> <ul aria-labelledby="navbarDrop1" role="menu"> <li><a tabindex="-1" href="#one">one</a></li> <li><a tabindex="-1" href="#two">two</a></li> <!----分割线--> <li></li> <li><a tabindex="-1" href="#three">three</a></li> </ul> </li> </ul> <!----导航结束--> </div> </div> </nav> 滚动监对象 <div data-offset="0" data-target="#navbar-example2" data-spy="scroll"> <h4>@fat</h4> <p>Ad leggings keytar,</p> <h4>@mdo</h4> <p>Veniam marfa mustache skateboard</p> <h4>one</h4> <p>Occaecat commodo aliqua delectus.</p> <h4>two</h4> <p>In incididunt echo park, officia deserunt mcsweeney's </p> <h4>three</h4> <p>Ad leggings keytar</p> <p>Keytar twee blog</p> </div> </div> </div> <script src="https://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwdffd.html