欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Bootstrap滾動監(jiān)聽(Scrollspy)插件詳解

 更新時間:2016年04月26日 16:48:29   投稿:lijiao  
滾動監(jiān)聽插件是用來根據(jù)滾動條所處在的位置自動更新導(dǎo)航項目, 顯示導(dǎo)航項目高亮顯示。這篇文章主要介紹了Bootstrap滾動監(jiān)聽(Scrollspy)插件的相關(guān)資料,需要的朋友可以參考下

滾動監(jiān)聽(Scrollspy)插件,即自動更新導(dǎo)航插件,會根據(jù)滾動條的位置自動更新對應(yīng)的導(dǎo)航目標。其基本的實現(xiàn)是隨著您的滾動,基于滾動條的位置向?qū)Ш綑谔砑?.active class。

如果您想要單獨引用該插件的功能,那么您需要引用 scrollspy.js?;蛘?,正如 Bootstrap 插件概覽 一章中所提到,您可以引用 bootstrap.js 或壓縮版的 bootstrap.min.js。

一、用法
您可以向頂部導(dǎo)航添加滾動監(jiān)聽行為:

1、通過 data 屬性:向您想要監(jiān)聽的元素(通常是 body)添加 data-spy="scroll"。然后添加帶有 Bootstrap .nav 組件的父元素的 ID 或 class 的屬性 data-target。為了它能正常工作,您必須確保頁面主體中有匹配您所要監(jiān)聽鏈接的 ID 的元素存在。

<body data-spy="scroll" data-target=".navbar-example">
 ...
 <div class="navbar-example">
  <ul class="nav nav-tabs">
   ...
  </ul>
 </div>
 ...
</body>

2、通過 JavaScript:您可以通過 JavaScript 調(diào)用滾動監(jiān)聽,選取要監(jiān)聽的元素,然后調(diào)用 .scrollspy() 函數(shù):
$('body').scrollspy({ target: '.navbar-example' })
二、滾動監(jiān)聽
滾動監(jiān)聽插件是用來根據(jù)滾動條所處在的位置自動更新導(dǎo)航項目, 顯示導(dǎo)航項目高亮顯示。

//基本實例
<nav id="nav" class="navbar navbar-default">
  <a href="#" class="navbar-brand">Web 開發(fā)</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>
    標準通用標記語言下的一個應(yīng)用 HTML 標準自 1999 年 12 月發(fā)布的 HTML4.01后,后繼的 HTML5 和其它標準被束之高閣,為了推動 Web 標準化運動的發(fā)展,一些公司聯(lián)合起來,成立了一個叫做 Web Hypertext Application Technology Working Group(Web 超文本應(yīng)用技術(shù)工作組 -WHATWG) 的組織。WHATWG 致力于 Web 表單和應(yīng)用程序,而 W3C(World Wide Web Consortium,萬維網(wǎng)聯(lián)盟) 專注于 XHTML2.0。在 2006 年,

    雙方?jīng)Q定進行合作,來創(chuàng)建一個新版本的 HTML。
  </p>
  <h4 id="bootstrap">Bootstrap</h4>
  <p>
    Bootstrap,來自 Twitter,是目前很受歡迎的前端框架。Bootstrap 是基于 HTML、 CSS、 JAVASCRIPT 的, 它簡潔靈活, 使得 Web 開發(fā)更加快捷。 [1]它由 Twitter的設(shè)計師 Mark Otto 和 Jacob Thornton 合作開發(fā),是一個 CSS/HTML 框架。Bootstrap提供了優(yōu)雅的 HTML 和 CSS 規(guī)范,它即是由動態(tài) CSS 語言 Less 寫成。Bootstrap 一經(jīng)推出后頗受歡迎,一直是 GitHub 上的熱門開源項目,包括 NASA 的 MSNBC(微軟全國廣播公司)的 Breaking News 都使用了該項目。[2]國內(nèi)一些移動開發(fā)者較為熟悉的框架,如 WeX5前端開源框架等,也是基于 Bootstrap 源碼進行性能優(yōu)化而來。[3]
  </p>
  <h4 id="jquery">jQuery</h4>
  <p>
    JQuery 是繼 prototype 之后又一個優(yōu)秀的 Javascript 庫。 它是輕量級的 js庫 ,它兼容 CSS3,還兼容各種瀏覽器(IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+) ,jQuery2.0 及后續(xù)版本將不再支持 IE6/7/8 瀏覽器。jQuery 使用戶能更方便地處理 HTML(標準通用標記語言下的一個應(yīng)用) 、 events、 實現(xiàn)動畫效果, 并且方便地為網(wǎng)站提供 AJAX交互。jQuery 還有一個比較大的優(yōu)勢是,它的文檔說明很全,而且各種應(yīng)用也說得很詳細,同時還有許多成熟的插件可供選擇。 jQuery 能夠使用戶的 html 頁面保持代碼和 html 內(nèi)容分離, 也就是說, 不用再在 html 里面插入一堆 js 來調(diào)用命令了, 只需要定義 id 即可。
  </p>
  <h4 id="yui">Yui</h4>
  <p>
    近幾年隨著 jQuery、Ext 以及 CSS3 的發(fā)展,以 Bootstrap 為代表的前端開發(fā)框架如雨后春筍般擠入視野, 可謂應(yīng)接不暇。 不論是桌面瀏覽器端還是移動端都涌現(xiàn)出很多優(yōu)秀的框架,極大豐富了開發(fā)素材,也方便了大家的開發(fā)。這些框架各有特點,本文對這些框架進行初步的介紹與比較, 希望能夠為大家選擇框架提供一點幫助, 也為后續(xù)詳細研究這些框架的拋磚引玉。
  </p>
  <h4 id="extjs">Extjs</h4>
  <p>
    ExtJS 可以用來開發(fā) RIA 也即富客戶端的 AJAX 應(yīng)用,是一個用 javascript寫的,主要用于創(chuàng)建前端用戶界面,是一個與后臺技術(shù)無關(guān)的前端 ajax 框架。因此,可以把 ExtJS 用在.Net、Java、Php 等各種開發(fā)語言開發(fā)的應(yīng)用中。ExtJs 最開始基于 YUI 技術(shù),由開發(fā)人員 JackSlocum 開發(fā),通過參考 JavaSwing 等機制來組織可視化組件,無論從 UI 界面上 CSS 樣式的應(yīng)用,到數(shù)據(jù)解析上的異常處理,都可算是一款不可多得的JavaScript 客戶端技術(shù)的精品。
  </p>
</div>

這里有兩個重要的屬性,如下圖:


PS:在一個菜單和一個容易的時候,data-target 不設(shè)置也可以穩(wěn)定實現(xiàn)滾動監(jiān)聽高亮。但多個導(dǎo)航時,你不關(guān)聯(lián)其中一個,會導(dǎo)致錯誤,所以,一般要加上。

如果使用 JavaScript 腳本方式, 可以去掉 data-*, 使用腳本屬性定義: offset、 spy和 target。具體方法如下:

//使用腳本方式定義屬性

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

滾動監(jiān)聽還有一個切換到新條目的事件。

//事件綁定在導(dǎo)航上

$('#nav').on('activate.bs.scrollspy', function() {
    alert('新條目被激活后觸發(fā)此事件!');
});
滾動監(jiān)聽還有一個更新容器 DOM 的方法。

//HTML 部分

<section class="sec">
  <h4 id="html5">HTML5 <a href="#" onclick="removeSec(this)">刪除此項</a></h4>
  <p>
    ...
  </p>
</section>

//刪除內(nèi)容時,刷新一下 DOM,避免導(dǎo)航監(jiān)聽錯位

function removeSec(e) {
  $(e).parents('.sec').remove();
  $('#content').scrollspy('refresh');
}

注意:這個方法必須使用 data-*聲明式。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • JS簡單獲取客戶端IP地址的方法【調(diào)用搜狐接口】

    JS簡單獲取客戶端IP地址的方法【調(diào)用搜狐接口】

    這篇文章主要介紹了JS簡單獲取客戶端IP地址的方法,通過調(diào)用搜狐接口來簡單實現(xiàn)獲取訪客IP地址的功能,非常簡便實用,需要的朋友可以參考下
    2016-09-09
  • webpack HappyPack實戰(zhàn)詳解

    webpack HappyPack實戰(zhàn)詳解

    這篇文章主要介紹了webpack HappyPack實戰(zhàn)詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 在JavaScript中使用for循環(huán)的方法

    在JavaScript中使用for循環(huán)的方法

    這篇文章主要介紹了如何在JavaScript中使用for循環(huán),通過使用JavaScript?for...in循環(huán),我們可以循環(huán)對象的鍵或?qū)傩?,在迭代對象屬性或進行調(diào)試時,它可能很有用,但在迭代數(shù)組或?qū)ο筮M行修改時,應(yīng)該避免使用for...in循環(huán),需要的朋友可以參考下
    2022-11-11
  • echarts中地圖重疊問題解決

    echarts中地圖重疊問題解決

    在使用Echarts開發(fā)項目時,經(jīng)常會遇到地圖組件的開發(fā),困擾許久的地圖重疊問題,本文就來解決一下這個問題,感興趣的可以了解一下
    2023-08-08
  • JavaScript該如何學(xué)習(xí) 怎樣輕松學(xué)習(xí)JavaScript

    JavaScript該如何學(xué)習(xí) 怎樣輕松學(xué)習(xí)JavaScript

    JavaScript該如何學(xué)習(xí)?如何輕松學(xué)習(xí)JavaScript?這篇文章主要介紹了輕松學(xué)習(xí)JavaScript的方法
    2017-06-06
  • 快速排序 php與javascript的不同之處

    快速排序 php與javascript的不同之處

    告訴你一個排序算法,也許是最重要的是他們知道 - 快速排序,無論是在PHP和JavaScript實現(xiàn)的。雖然這兩種語言之間的代碼看起來相似,也有一些差異,這表明了語法知識的重要性!
    2011-02-02
  • js判斷變量是否未定義的代碼

    js判斷變量是否未定義的代碼

    一般如果變量通過var聲明,但是并未初始化的時候,變量的值為undefined,而未定義的變量則需要通過 "typeof 變量"的形式來判斷,否則會發(fā)生錯誤
    2012-11-11
  • js數(shù)組中去除重復(fù)值的幾種方法

    js數(shù)組中去除重復(fù)值的幾種方法

    這篇文章主要介紹了js數(shù)組中去除重復(fù)值的幾種方法,文中講解非常細致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-08-08
  • JS中call和apply函數(shù)用法實例分析

    JS中call和apply函數(shù)用法實例分析

    這篇文章主要介紹了JS中call和apply函數(shù)用法,結(jié)合實例形式較為詳細的分析了call和apply函數(shù)繼承功能的使用方法、區(qū)別及操作注意事項,需要的朋友可以參考下
    2018-06-06
  • 微信小程序點擊生成朋友圈分享圖(遇到的坑)

    微信小程序點擊生成朋友圈分享圖(遇到的坑)

    這篇文章主要介紹了微信小程序 點擊生成朋友圈分享圖,本文給大家分享小編在實現(xiàn)此功能時遇到的各種坑,通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06

最新評論