Bootstrap模塊dropdown實現(xiàn)下拉框響應(yīng)
本文介紹了Bootstrap下拉框模塊dropdown的使用方法,供大家參考,具體內(nèi)容如下
一、源碼分析:
Dropdowns.scss:下拉框模塊
Javascripts/bootstrap/dropdown.js:實現(xiàn)下拉框響應(yīng)
二、功能及原理:
下拉選項卡,默認不能實現(xiàn)顯示選中項的功能
原理:
1、利用dropdown類作為定位點,然后讓子級的列表dropdown-menu絕對定位實現(xiàn),還需要加一個單擊點作為設(shè)置data-toggle=”dropdown”才能做關(guān)聯(lián)。
2、 需要js插件的支持
三、源碼分析:
1、caret:實現(xiàn)向下的三角形,利用邊框?qū)崿F(xiàn)的
1.1、邊框顏色默認是字體顏色
1.2、三角形的實現(xiàn):邊框要有寬度,然后相鄰兩邊需有寬度,但顏色透明;最后還需要元素為行內(nèi)塊元素,才能使其高、寬為0。
1.3、代碼如下
2、在document上綁定了click事件的監(jiān)聽,監(jiān)聽類型為data-toggle=”dropdown”。
3、Js插件寫的Plugin函數(shù),和類的構(gòu)造函數(shù)是用于js方式調(diào)用插件;
4、而data-*模式調(diào)用插件,用到是向document注入事件實現(xiàn)的,代碼如下:
$(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)
代碼直接調(diào)用了Dropdown定義的方法,這里經(jīng)妙的設(shè)計在于插件的框架,data-*模式的調(diào)用與Js插件模式的調(diào)用,而這兩種調(diào)用模式卻利用了同一份代碼。
5、如果用Js插件調(diào)用,基礎(chǔ)方法都要自己調(diào)用才行,在創(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”:是為了實現(xiàn)單擊,展開指定的下拉列表,默認是展開與按鈕后面兄弟節(jié)點:
<ul class="nav nav-pills navbar-nav"> <li><a>Index</a></li> <li><a>產(chǎn)呂</a></li> <li > <a data-toggle="dropdown" href="#name" >實用工具</a></li> </ul> <div id="name" > <ul class="dropdown-menu" > <li><a>關(guān)于我們</a></li> </ul> </div>
10、實現(xiàn)向上彈出子菜單,用bottom:100%(彈出子菜單bottom的定位)實現(xiàn)
11、應(yīng)用示例
<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>
如果大家還想深入學習,可以點擊這里進行學習,再為大家附兩個精彩的專題:Bootstrap學習教程 Bootstrap實戰(zhàn)教程
以上就是本文的全部內(nèi)容,希望對大家學習javascript程序設(shè)計有所幫助。
- BootStrap中關(guān)于Select下拉框選擇觸發(fā)事件及擴展
- Bootstrap select多選下拉框?qū)崿F(xiàn)代碼
- bootstrap下拉列表與輸入框組結(jié)合的樣式調(diào)整
- Bootstrap每天必學之下拉菜單
- Bootstrap框架下下拉框select搜索功能
- Bootstrap Table 在指定列中添加下拉框控件并獲取所選值
- Bootstrap每天必學之級聯(lián)下拉菜單
- bootstrap中selectpicker下拉框使用方法實例
- Bootstrap中的Dropdown下拉菜單更改為懸停(hover)觸發(fā)
- IE11下CKEditor在Bootstrap Modal中下拉問題的解決
相關(guān)文章
javascript 支持ie和firefox杰奇翻頁函數(shù)
杰奇小說系統(tǒng)用到的翻頁函數(shù),支持firefox,官方自帶的模板不支持,這樣大家就可以用firefox瀏覽網(wǎng)頁了,在網(wǎng)頁木馬橫行的今天,firefox比ie要安全不少2008-07-07JavaScript使用鏈式方法封裝jQuery中CSS()方法示例
這篇文章主要介紹了JavaScript使用鏈式方法封裝jQuery中CSS()方法,結(jié)合具體實例形式分析了JS采用鏈式操作方法封住jQuery中連綴操作實現(xiàn)css()方法的相關(guān)技巧,需要的朋友可以參考下2017-04-04微信小程序獲取地理位置及經(jīng)緯度授權(quán)代碼實例
這篇文章主要介紹了微信小程序獲取地理位置及經(jīng)緯度授權(quán)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-09-09