目錄
#基本用法
【膠囊式選項卡】
首頁 web前端 Bootstrap教程 一起來了解下Bootstrap中的tab選項卡

一起來了解下Bootstrap中的tab選項卡

Apr 13, 2021 am 10:02 AM
bootstrap

這篇文章帶大家一起了解下Bootstrap中的tab選項卡。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

一起來了解下Bootstrap中的tab選項卡

選項卡Tabs是Web中非常常用的功能。使用者點擊對選單項,能切換出對應的內容。本文將詳細介紹Bootstrap選項卡【相關推薦:《bootstrap教程》】

#基本用法

  Bootstrap框架中的選項卡主要有兩部分內容組成:

  1、選項卡選單元件,對應的是Bootstrap的 nav-tabs

  2、可切換的選項卡面板元件,在Bootstrap 中通常 tab-pane 來表示

  在Bootstrap框架中選項卡nav-tabs已帶有樣式,而對於面板內容tab-pane都是隱藏的,只有當前面板內容才是顯示的

.tab-content > .tab-pane {
    display: none;
}
.tab-content > .active {
    display: block;
}
登入後複製

  選項卡定義data屬性來觸發切換效果。當然前提要先載入bootstrap.js或是tab.js。宣告式觸發標籤需要符合以下幾點要求:

  1、選項卡導覽連結中要設定 data-toggle="tab"

  2、並且設定 data-target="對應內容面板的選擇符(一般是ID)";如果是連結的話,還可以透過 href="對應內容面板的選擇符(一般是ID)",主要作用是使用者點擊的時候能找到該選擇符所對應的面板內容tab-pane。

  3、面板內容統一放在tab-content 容器中,而且每個內容面板tab-pane 都需要設定一個獨立的選擇符(最好是ID)與選項卡中的 data-target 或href 的值符合

<!-- 选项卡菜单-->
<ul id="myTab" class="nav nav-tabs" role="tablist">
    <li class="active"><a href="#bulletin" role="tab" data-toggle="tab">公告</a></li>
    <li><a href="#rule" role="tab" data-toggle="tab">规则</a></li>
    <li><a href="#forum" role="tab" data-toggle="tab">论坛</a></li>
    <li><a href="#security" role="tab"  data-toggle="tab">安全</a></li>
    <li><a href="#welfare" role="tab" data-toggle="tab">公益</a></li>
</ul>
<!-- 选项卡面板 -->
<div id="myTabContent" class="tab-content">
    <div class="tab-pane active" id="bulletin">公告内容面板</div>
    <div class="tab-pane " id="rule">规则内容面板</div>
    <div class="tab-pane " id="forum">论坛内容面板</div>
    <div class="tab-pane " id="security">安全内容面板</div>
    <div class="tab-pane " id="welfare">公益内容面板</div>
</div>
登入後複製

一起來了解下Bootstrap中的tab選項卡

【漸入效果】

  為了讓面板的隱藏與顯示在切換的過程效果更流暢,可在面板中加入類別名稱 fade,讓其產生漸入的效果。

  在新增fade 樣式時,最初的預設顯示的內容面板一定要加上 in 類別名,不然使用者無法看到其內容

<!-- 选项卡菜单-->
<ul id="myTab" class="nav nav-tabs" role="tablist">
    <li class="active"><a href="#bulletin" role="tab" data-toggle="tab">公告</a></li>
    <li><a href="#rule" role="tab" data-toggle="tab">规则</a></li>
    <li><a href="#forum" role="tab" data-toggle="tab">论坛</a></li>
    <li><a href="#security" role="tab"  data-toggle="tab">安全</a></li>
    <li><a href="#welfare" role="tab" data-toggle="tab">公益</a></li>
</ul>
<!-- 选项卡面板 -->
<div id="myTabContent" class="tab-content">
    <div class="tab-pane fade in active" id="bulletin">公告内容面板</div>
    <div class="tab-pane fade" id="rule">规则内容面板</div>
    <div class="tab-pane fade" id="forum">论坛内容面板</div>
    <div class="tab-pane fade" id="security">安全内容面板</div>
    <div class="tab-pane fade" id="welfare">公益内容面板</div>
</div>
登入後複製

一起來了解下Bootstrap中的tab選項卡

一起來了解下Bootstrap中的tab選項卡

【膠囊式選項卡】

  在Bootstrap除了可以讓 nav-tabs 具有選項卡的切換功能之外,還可以讓膠囊式 nav-pills 導航也具有選項卡的功能。只需要將nav-tabs 換成nav-pills,另外關鍵一點是將 

data-toggle="tab"

換成data-toggle="pill"

<!-- 选项卡菜单-->
<ul id="myTab" class="nav nav-pills" role="tablist">
    <li class="active"><a href="#bulletin" role="tab" data-toggle="pill">公告</a></li>
    <li><a href="#rule" role="tab" data-toggle="pill">规则</a></li>
    <li><a href="#forum" role="tab" data-toggle="pill">论坛</a></li>
    <li><a href="#security" role="tab" data-toggle="pill">安全</a></li>
    <li><a href="#welfare" role="tab" data-toggle="pill">公益</a></li>
</ul>
<!-- 选项卡面板 -->
<div id="myTabContent" class="tab-content">
    <div class="tab-pane fade in active" id="bulletin">公告内容面板</div>
    <div class="tab-pane fade" id="rule">规则内容面板</div>
    <div class="tab-pane fade" id="forum">论坛内容面板</div>
    <div class="tab-pane fade" id="security">安全内容面板</div>
    <div class="tab-pane fade" id="welfare">公益内容面板</div>
</div>
登入後複製

一起來了解下Bootstrap中的tab選項卡

JS觸發

  除了在HTML設定data-toggle 來觸發選項卡之外,還可以透過JavaScript直接呼叫。 一起來了解下Bootstrap中的tab選項卡

  在每個連結的點選事件中呼叫

tab("show")方法,顯示對應的標籤面板內容。針對上面的範例,刪除HTML中自訂的data-toggle="tab" 或data-toggle="pill" 的屬性,然後透過下面的腳本來呼叫
$(function(){
    $("#myTab a").click(function(e){
        e.preventDefault();
        $(this).tab("show");
    });
})
登入後複製



公告内容面板
规则内容面板
论坛内容面板
安全内容面板
公益内容面板
<script> $(function(){ $(&quot;#myTab a&quot;).click(function(e){ e.preventDefault(); $(this).tab(&quot;show&quot;); }); }) </script>
登入後複製

#【事件訂閱】

show.bs.tab        show方法调用之后立即触发该事件
shown.bs.tab      此事件在tab已经显示出来(并且同时在 CSS 过渡效果完成)之后被触发
hide.bs.tab        hide方法调用之后立即触发该事件。
hidden.bs.tab     此事件在tab被隐藏(并且同时在 CSS 过渡效果完成)之后被触发
登入後複製
<!-- 选项卡菜单-->
<ul id="myTab" class="nav nav-pills" role="tablist">
    <li class="active"><a href="#bulletin" role="tab">公告</a></li>
    <li><a href="#rule" role="tab" >规则</a></li>
    <li><a href="#forum" role="tab" >论坛</a></li>
    <li><a href="#security" role="tab" >安全</a></li>
    <li><a href="#welfare" role="tab" >公益</a></li>
</ul>
<!-- 选项卡面板 -->
<div id="myTabContent" class="tab-content">
    <div class="tab-pane fade in active" id="bulletin">公告内容面板</div>
    <div class="tab-pane fade" id="rule">规则内容面板</div>
    <div class="tab-pane fade" id="forum">论坛内容面板</div>
    <div class="tab-pane fade" id="security">安全内容面板</div>
    <div class="tab-pane fade" id="welfare">公益内容面板</div>
</div>
<script>
$(function(){
    $("#myTab a").click(function(e){
        e.preventDefault();
        $(this).tab("show");
    });
    $("#myTab").on("show.bs.tab",function(e){
         $(e.target).css(&#39;outline&#39;,&#39;1px solid black&#39;);    
    }).on("hide.bs.tab",function(e){
        $(e.target).css(&#39;outline&#39;,&#39;none&#39;);  
    })
})
</script>
登入後複製

#JS原始碼

##【1】IIFE

#  使用立即呼叫函數,防止插件內程式碼外洩,從而形成一個閉環,並且只能從jQuery的fn裡進行擴展

【2】初始設定

var Tab = function (element) {
    //指定当前元素
    this.element = $(element)
  }
  //版本号为3.3.7
  Tab.VERSION = &#39;3.3.7&#39;
  //动画时间为150ms
  Tab.TRANSITION_DURATION = 150
登入後複製
###【3 】外掛核心程式碼###
//show()方法用于触发show事件,调用activate原型方法,触发shown事件
  Tab.prototype.show = function () {
    //当前tab
    var $this    = this.element
    //找到最近的ul
    var $ul      = $this.closest(&#39;ul:not(.dropdown-menu)&#39;)
    //找到data-target值
    var selector = $this.data(&#39;target&#39;)
    //如果data-target值不存在,查找href值
    if (!selector) {
      selector = $this.attr(&#39;href&#39;)
      //IE7特殊处理
      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, &#39;&#39;) 
    }
    //如果当前tab已经是活动状态了,即父元素li上已经有active样式的话,直接返回
    if ($this.parent(&#39;li&#39;).hasClass(&#39;active&#39;)) return
    //找到上一个元素,即上一个带有active样式的li里的a元素
    var $previous = $ul.find(&#39;.active:last a&#39;)
    //设置hide事件
    var hideEvent = $.Event(&#39;hide.bs.tab&#39;, {
      relatedTarget: $this[0]
    })
    //设置show事件
    var showEvent = $.Event(&#39;show.bs.tab&#39;, {
      relatedTarget: $previous[0]
    })
    //触发hide事件及show事件
    $previous.trigger(hideEvent)
    $this.trigger(showEvent)
    //如果自定义回调中阻止了默认行为,则不再继续处理
    if (showEvent.isDefaultPrevented() || hideEvent.isDefaultPrevented()) return
    //要激活显示的面板,即target或href里的值所对应的元素
    var $target = $(selector)
    //高亮显示当前tab
    this.activate($this.closest(&#39;li&#39;), $ul)
    //显示对应的面板,并在回调里触发hidden及shown事件
    this.activate($target, $target.parent(), function () {
      $previous.trigger({
        type: &#39;hidden.bs.tab&#39;,
        relatedTarget: $this[0]
      })
      $this.trigger({
        type: &#39;shown.bs.tab&#39;,
        relatedTarget: $previous[0]
      })
    })
  }
  //active样式的应用,面板的显示和隐藏,以及tab的高亮与反高亮
  Tab.prototype.activate = function (element, container, callback) {
    //查找当前容器所有有active样式的元素
    var $active    = container.find(&#39;> .active&#39;)
    //判断是使用回调还是动画
    var transition = callback
      && $.support.transition
      && ($active.length && $active.hasClass(&#39;fade&#39;) || !!container.find(&#39;> .fade&#39;).length)

    function next() {
      $active
        //去除其他元素的active样式
        .removeClass(&#39;active&#39;)
        //包括li元素里面的下拉菜单里的active样式也要去除
        .find(&#39;> .dropdown-menu > .active&#39;)
          .removeClass(&#39;active&#39;)
        .end()
        .find(&#39;[data-toggle="tab"]&#39;)
          .attr(&#39;aria-expanded&#39;, false)

      element
        //给当前被单击的元素添加active高亮样式
        .addClass(&#39;active&#39;)
        .find(&#39;[data-toggle="tab"]&#39;)
          .attr(&#39;aria-expanded&#39;, true)

      if (transition) {
        //如果支持动画,就重绘页面
        element[0].offsetWidth 
        //并添加in样式,去除透明
        element.addClass(&#39;in&#39;)
      } else {
        //否则删除fade
        element.removeClass(&#39;fade&#39;)
      }
      //如果单击的是下拉菜单里的项目
      if (element.parent(&#39;.dropdown-menu&#39;).length) {
        element
          //打到最近的li.dropdown元素进行高亮
          .closest(&#39;li.dropdown&#39;)
            .addClass(&#39;active&#39;)
          .end()
          .find(&#39;[data-toggle="tab"]&#39;)
            .attr(&#39;aria-expanded&#39;, true)
      }
      //如果有回调就执行回调
      callback && callback()
    }
    //如果支持动画
    $active.length && transition ?
      $active
        //在动画结束后执行next()
        .one(&#39;bsTransitionEnd&#39;, next)
        .emulateTransitionEnd(Tab.TRANSITION_DURATION) :
      next()

    $active.removeClass(&#39;in&#39;)
  }
登入後複製
###【4】jQuery外掛定義###
function Plugin(option) {
    //根据选择器,遍历所有符合规则的元素
    return this.each(function () {
      var $this = $(this)
      //获取自定义属性bs.tab的值
      var data  = $this.data(&#39;bs.tab&#39;)
      //如果值不存在,则将Tab实例设置为bs.tab值
      if (!data) $this.data(&#39;bs.tab&#39;, (data = new Tab(this)))
      //如果option传递了string,则表示要执行某个方法  
      if (typeof option == &#39;string&#39;) data[option]()
    })
  }

  var old = $.fn.tab
  //保留其他库的$.fn.tab代码(如果定义的话),以便在noConflict之后可以继续使用该老代码
  $.fn.tab             = Plugin
  //重设插件构造器,可以通过该属性获取插件的真实类函数
  $.fn.tab.Constructor = Tab
登入後複製
###【5】防衝突處理###
$.fn.tab.noConflict = function () {
     //恢复以前的旧代码
    $.fn.tab = old
    //将$.fn.tab.noConflict()设置为Bootstrap的Tab插件
    return this
  }
登入後複製
###【6】綁定觸發事件###
var clickHandler = function (e) {
    //阻止默认行为
    e.preventDefault()
    //触发show()方法
    Plugin.call($(this), &#39;show&#39;)
  }

  $(document)
    //在document上绑定单击事件
    .on(&#39;click.bs.tab.data-api&#39;, &#39;[data-toggle="tab"]&#39;, clickHandler)
    .on(&#39;click.bs.tab.data-api&#39;, &#39;[data-toggle="pill"]&#39;, clickHandler)
登入後複製
## #更多程式相關知識,請造訪:###程式設計影片###! ! ###

以上是一起來了解下Bootstrap中的tab選項卡的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

vue中怎麼用bootstrap vue中怎麼用bootstrap Apr 07, 2025 pm 11:33 PM

在 Vue.js 中使用 Bootstrap 分為五個步驟:安裝 Bootstrap。在 main.js 中導入 Bootstrap。直接在模板中使用 Bootstrap 組件。可選:自定義樣式。可選:使用插件。

bootstrap搜索欄怎麼獲取 bootstrap搜索欄怎麼獲取 Apr 07, 2025 pm 03:33 PM

如何使用 Bootstrap 獲取搜索欄的值:確定搜索欄的 ID 或名稱。使用 JavaScript 獲取 DOM 元素。獲取元素的值。執行所需的操作。

bootstrap垂直居中怎麼弄 bootstrap垂直居中怎麼弄 Apr 07, 2025 pm 03:21 PM

使用 Bootstrap 實現垂直居中:flexbox 法:使用 d-flex、justify-content-center 和 align-items-center 類,將元素置於 flexbox 容器內。 align-items-center 類法:對於不支持 flexbox 的瀏覽器,使用 align-items-center 類,前提是父元素具有已定義的高度。

bootstrap怎麼設置框架 bootstrap怎麼設置框架 Apr 07, 2025 pm 03:27 PM

要設置 Bootstrap 框架,需要按照以下步驟:1. 通過 CDN 引用 Bootstrap 文件;2. 下載文件並將其託管在自己的服務器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根據需要編譯 Sass/Less;5. 導入定製文件(可選)。設置完成後,即可使用 Bootstrap 的網格系統、組件和样式創建響應式網站和應用程序。

bootstrap怎麼寫分割線 bootstrap怎麼寫分割線 Apr 07, 2025 pm 03:12 PM

創建 Bootstrap 分割線有兩種方法:使用 標籤,可創建水平分割線。使用 CSS border 屬性,可創建自定義樣式的分割線。

bootstrap怎麼插入圖片 bootstrap怎麼插入圖片 Apr 07, 2025 pm 03:30 PM

在 Bootstrap 中插入圖片有以下幾種方法:直接插入圖片,使用 HTML 的 img 標籤。使用 Bootstrap 圖像組件,可以提供響應式圖片和更多樣式。設置圖片大小,使用 img-fluid 類可以使圖片自適應。設置邊框,使用 img-bordered 類。設置圓角,使用 img-rounded 類。設置陰影,使用 shadow 類。調整圖片大小和位置,使用 CSS 樣式。使用背景圖片,使用 background-image CSS 屬性。

bootstrap按鈕怎麼用 bootstrap按鈕怎麼用 Apr 07, 2025 pm 03:09 PM

如何使用 Bootstrap 按鈕?引入 Bootstrap CSS創建按鈕元素並添加 Bootstrap 按鈕類添加按鈕文本

bootstrap怎麼調整大小 bootstrap怎麼調整大小 Apr 07, 2025 pm 03:18 PM

要調整 Bootstrap 中元素大小,可以使用尺寸類,具體包括:調整寬度:.col-、.w-、.mw-調整高度:.h-、.min-h-、.max-h-

See all articles