Rumah >hujung hadapan web >tutorial js >Penjelasan terperinci kemahiran pemantauan tatal Bootstrap (Scrollspy) plug-in_javascript

Penjelasan terperinci kemahiran pemantauan tatal Bootstrap (Scrollspy) plug-in_javascript

WBOY
WBOYasal
2016-05-16 15:03:382195semak imbas

Pemalam Scrollspy, yang merupakan pemalam navigasi kemas kini automatik, akan mengemas kini sasaran navigasi yang sepadan secara automatik mengikut kedudukan bar skrol. Pelaksanaan asas ialah menambah kelas .aktif pada bar navigasi berdasarkan kedudukan bar skrol semasa anda menatal.

Jika anda ingin merujuk kefungsian pemalam ini secara berasingan, maka anda perlu merujuk scrollspy.js. Sebagai alternatif, seperti yang dinyatakan dalam bab Gambaran Keseluruhan Plugin Bootstrap, anda boleh merujuk bootstrap.js atau versi mini bootstrap.min.js.

1
Anda boleh menambah gelagat mendengar tatal pada navigasi atas:

1. Melalui atribut data: tambah data-spy="scroll" pada elemen yang ingin anda pantau (biasanya badan). Kemudian tambahkan sasaran data atribut dengan ID atau kelas elemen induk bagi komponen Bootstrap .nav. Untuk ini berfungsi, anda mesti memastikan bahawa unsur wujud dalam badan halaman yang sepadan dengan ID pautan yang anda mahu dengar.


<body data-spy="scroll" data-target=".navbar-example">
 ...
 <div class="navbar-example">
  <ul class="nav nav-tabs">
   ...
  </ul>
 </div>
 ...
</body>
2. Melalui JavaScript: Anda boleh memanggil pemantauan tatal melalui JavaScript, pilih elemen yang ingin anda pantau, dan kemudian panggil fungsi .scrollspy():

$('body').scrollspy({ target: '.navbar-example' })

2. Pemantauan tatal
Pemalam mendengar tatal digunakan untuk mengemas kini item navigasi secara automatik berdasarkan kedudukan bar tatal dan memaparkan sorotan item navigasi.

//基本实例
<nav id="nav" class="navbar navbar-default">
  <a href="#" class="navbar-brand">Web 开发</a>
  <ul class="nav navbar-nav">
    <li>
      <a href="#html5">HTML5</a>
    </li>
    <li>
      <a href="#bootstrap">Bootstrap</a>
    </li>
    <li class="dropdown">
      <a href="#" data-toggle="dropdown">JavaScript <span class="caret"></span></a>
      <ul class="dropdown-menu">
        <li>
          <a href="#jquery">jQuery</a>
        </li>
        <li>
          <a href="#yui">Yui</a>
        </li>
        <li>
          <a href="#extjs">Extjs</a>
        </li>
      </ul>
    </li>
  </ul>
</nav>

<div data-offset="0" data-target="#nav" data-spy="scroll" style="height: 200px; overflow: auto; position: relative;padding: 0 10px;">
  <h4 id="html5">HTML5</h4>
  <p>
    标准通用标记语言下的一个应用 HTML 标准自 1999 年 12 月发布的 HTML4.01后,后继的 HTML5 和其它标准被束之高阁,为了推动 Web 标准化运动的发展,一些公司联合起来,成立了一个叫做 Web Hypertext Application Technology Working Group(Web 超文本应用技术工作组 -WHATWG) 的组织。WHATWG 致力于 Web 表单和应用程序,而 W3C(World Wide Web Consortium,万维网联盟) 专注于 XHTML2.0。在 2006 年,

    双方决定进行合作,来创建一个新版本的 HTML。
  </p>
  <h4 id="bootstrap">Bootstrap</h4>
  <p>
    Bootstrap,来自 Twitter,是目前很受欢迎的前端框架。Bootstrap 是基于 HTML、 CSS、 JAVASCRIPT 的, 它简洁灵活, 使得 Web 开发更加快捷。 [1]它由 Twitter的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS/HTML 框架。Bootstrap提供了优雅的 HTML 和 CSS 规范,它即是由动态 CSS 语言 Less 写成。Bootstrap 一经推出后颇受欢迎,一直是 GitHub 上的热门开源项目,包括 NASA 的 MSNBC(微软全国广播公司)的 Breaking News 都使用了该项目。[2]国内一些移动开发者较为熟悉的框架,如 WeX5前端开源框架等,也是基于 Bootstrap 源码进行性能优化而来。[3]
  </p>
  <h4 id="jquery">jQuery</h4>
  <p>
    JQuery 是继 prototype 之后又一个优秀的 Javascript 库。 它是轻量级的 js库 ,它兼容 CSS3,还兼容各种浏览器(IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+) ,jQuery2.0 及后续版本将不再支持 IE6/7/8 浏览器。jQuery 使用户能更方便地处理 HTML(标准通用标记语言下的一个应用) 、 events、 实现动画效果, 并且方便地为网站提供 AJAX交互。jQuery 还有一个比较大的优势是,它的文档说明很全,而且各种应用也说得很详细,同时还有许多成熟的插件可供选择。 jQuery 能够使用户的 html 页面保持代码和 html 内容分离, 也就是说, 不用再在 html 里面插入一堆 js 来调用命令了, 只需要定义 id 即可。
  </p>
  <h4 id="yui">Yui</h4>
  <p>
    近几年随着 jQuery、Ext 以及 CSS3 的发展,以 Bootstrap 为代表的前端开发框架如雨后春笋般挤入视野, 可谓应接不暇。 不论是桌面浏览器端还是移动端都涌现出很多优秀的框架,极大丰富了开发素材,也方便了大家的开发。这些框架各有特点,本文对这些框架进行初步的介绍与比较, 希望能够为大家选择框架提供一点帮助, 也为后续详细研究这些框架的抛砖引玉。
  </p>
  <h4 id="extjs">Extjs</h4>
  <p>
    ExtJS 可以用来开发 RIA 也即富客户端的 AJAX 应用,是一个用 javascript写的,主要用于创建前端用户界面,是一个与后台技术无关的前端 ajax 框架。因此,可以把 ExtJS 用在.Net、Java、Php 等各种开发语言开发的应用中。ExtJs 最开始基于 YUI 技术,由开发人员 JackSlocum 开发,通过参考 JavaSwing 等机制来组织可视化组件,无论从 UI 界面上 CSS 样式的应用,到数据解析上的异常处理,都可算是一款不可多得的JavaScript 客户端技术的精品。
  </p>
</div>

Terdapat dua atribut penting di sini, seperti yang ditunjukkan di bawah:


PS: Dalam menu dan situasi yang mudah, penyerlahan pemantauan menatal boleh dilaksanakan secara stabil tanpa tetapan sasaran data. Tetapi apabila terdapat berbilang navigasi, jika anda tidak mengaitkan salah satu daripadanya, ia akan menyebabkan ralat, jadi secara amnya anda perlu menambahkannya.

Jika anda menggunakan skrip JavaScript, anda boleh mengalih keluar data-* dan menggunakan atribut skrip untuk mentakrif: mengimbangi, mengintip dan menyasarkan. Kaedah khusus adalah seperti berikut:

//使用脚本方式定义属性

$('#content').scrollspy({
  offset : 0,
  target : '#nav',
}); 

Pendengar skrol juga mempunyai acara untuk bertukar kepada item baharu.

//Acara terikat pada navigasi

$('#nav').on('activate.bs.scrollspy', function() {

alert('Acara ini dicetuskan selepas entri baharu diaktifkan!');
});
Pendengar skrol juga mempunyai kaedah yang mengemas kini DOM bekas.

//Bahagian HTML

<section class="sec">
  <h4 id="html5">HTML5 <a href="#" onclick="removeSec(this)">删除此项</a></h4>
  <p>
    ...
  </p>
</section>
//Apabila memadamkan kandungan, muat semula DOM untuk mengelakkan salah letak pemantauan navigasi

function removeSec(e) {
  $(e).parents('.sec').remove();
  $('#content').scrollspy('refresh');
}
Nota: Kaedah ini mesti menggunakan pengisytiharan data-*.

Di atas adalah keseluruhan kandungan artikel ini, saya harap ia akan membantu kajian semua orang.

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn