Bootstrap模塊dropdown實現下拉框響應
來源:易賢網 閱讀:3067 次 日期:2016-06-25 13:14:24
溫馨提示:易賢網小編為您整理了“Bootstrap模塊dropdown實現下拉框響應”,方便廣大網友查閱!

這篇文章主要為大家詳細介紹了Bootstrap下拉框模塊dropdown實現下拉框響應,感興趣的朋友可以參考一下

本文介紹了Bootstrap下拉框模塊dropdown的使用方法,供大家參考,具體內容如下

一、源碼分析:

Dropdowns.scss:下拉框模塊 

Javascripts/bootstrap/dropdown.js:實現下拉框響應

二、功能及原理:

下拉選項卡,默認不能實現顯示選中項的功能

原理:

1、利用dropdown類作為定位點,然后讓子級的列表dropdown-menu絕對定位實現,還需要加一個單擊點作為設置data-toggle=”dropdown”才能做關聯。

2、 需要js插件的支持

三、源碼分析:

1、caret:實現向下的三角形,利用邊框實現的

1.1、邊框顏色默認是字體顏色

1.2、三角形的實現:邊框要有寬度,然后相鄰兩邊需有寬度,但顏色透明;最后還需要元素為行內塊元素,才能使其高、寬為0。

1.3、代碼如下

代碼如下:

<span style="border-left: 4px solid; border-top: 4px solid transparent; border-bottom: 4px solid transparent; height: 0px; width: 0px; line-height: normal; display: inline-block; "></span>

2、在document上綁定了click事件的監(jiān)聽,監(jiān)聽類型為data-toggle=”dropdown”。

3、Js插件寫的Plugin函數,和類的構造函數是用于js方式調用插件;

4、而data-*模式調用插件,用到是向document注入事件實現的,代碼如下:

$(document)

.on('click.bs.dropdown.data-api', clearMenus)

.on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })

.on('click.bs.dropdown.data-api', toggle, Dropdown.prototype.toggle)

.on('keydown.bs.dropdown.data-api', toggle, Dropdown.prototype.keydown)

.on('keydown.bs.dropdown.data-api','.dropdown-menu',Dropdown.prototype.keydown)

代碼直接調用了Dropdown定義的方法,這里經妙的設計在于插件的框架,data-*模式的調用與Js插件模式的調用,而這兩種調用模式卻利用了同一份代碼。

5、如果用Js插件調用,基礎方法都要自己調用才行,在創(chuàng)建實例時只會綁定toggle事件。

var Dropdown = function (element) {

 $(element).on('click.bs.dropdown', this.toggle)

}

6、clearMenu:只會清除data-toggle=”dropdown”的元素

7、dropdown-backdrop:用于移動沒有單擊事件的處理

8、keydown:當dropdown按鈕獲取焦點的時候,按下鍵可以展開,按上鍵收縮的功能

9、data-target和herf=”#id”:是為了實現單擊,展開指定的下拉列表,默認是展開與按鈕后面兄弟節(jié)點:

<ul class="nav nav-pills navbar-nav">

 <li><a>Index</a></li>

 <li><a>產呂</a></li>

 <li > <a data-toggle="dropdown" href="#name" >實用工具</a></li>

</ul>

<div id="name" >

 <ul class="dropdown-menu" >

  <li><a>關于我們</a></li>

 </ul>

</div>

10、實現向上彈出子菜單,用bottom:100%(彈出子菜單bottom的定位)實現

11、應用示例

<div id="dropdown" class="dropdown">

<a id="dropdown-btn" data-target="#dropdown" >number</a>

<ul class="dropdown-menu" >

  <li><a>3343</a></li>

<li><a>555</a></li>

</ul>

</div>

以上就是本文的全部內容,希望對大家學習javascript程序設計有所幫助。

更多信息請查看網絡編程
易賢網手機網站地址:Bootstrap模塊dropdown實現下拉框響應
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網