Bootstrap模塊dropdown實(shí)現(xiàn)下拉框響應(yīng)
本文介紹了Bootstrap下拉框模塊dropdown的使用方法,供大家參考,具體內(nèi)容如下
一、源碼分析:
Dropdowns.scss:下拉框模塊
Javascripts/bootstrap/dropdown.js:實(shí)現(xiàn)下拉框響應(yīng)
二、功能及原理:
下拉選項(xiàng)卡,默認(rèn)不能實(shí)現(xiàn)顯示選中項(xiàng)的功能
原理:
1、利用dropdown類作為定位點(diǎn),然后讓子級(jí)的列表dropdown-menu絕對(duì)定位實(shí)現(xiàn),還需要加一個(gè)單擊點(diǎn)作為設(shè)置data-toggle=”dropdown”才能做關(guān)聯(lián)。
2、 需要js插件的支持
三、源碼分析:
1、caret:實(shí)現(xiàn)向下的三角形,利用邊框?qū)崿F(xiàn)的
1.1、邊框顏色默認(rèn)是字體顏色
1.2、三角形的實(shí)現(xiàn):邊框要有寬度,然后相鄰兩邊需有寬度,但顏色透明;最后還需要元素為行內(nèi)塊元素,才能使其高、寬為0。
1.3、代碼如下
2、在document上綁定了click事件的監(jiān)聽(tīng),監(jiān)聽(tīng)類型為data-toggle=”dropdown”。
3、Js插件寫的Plugin函數(shù),和類的構(gòu)造函數(shù)是用于js方式調(diào)用插件;
4、而data-*模式調(diào)用插件,用到是向document注入事件實(shí)現(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è)計(jì)在于插件的框架,data-*模式的調(diào)用與Js插件模式的調(diào)用,而這兩種調(diào)用模式卻利用了同一份代碼。
5、如果用Js插件調(diào)用,基礎(chǔ)方法都要自己調(diào)用才行,在創(chuàng)建實(shí)例時(shí)只會(huì)綁定toggle事件。
var Dropdown = function (element) {
$(element).on('click.bs.dropdown', this.toggle)
}
6、clearMenu:只會(huì)清除data-toggle=”dropdown”的元素
7、dropdown-backdrop:用于移動(dòng)沒(méi)有單擊事件的處理
8、keydown:當(dāng)dropdown按鈕獲取焦點(diǎn)的時(shí)候,按下鍵可以展開(kāi),按上鍵收縮的功能
9、data-target和herf=”#id”:是為了實(shí)現(xiàn)單擊,展開(kāi)指定的下拉列表,默認(rèn)是展開(kāi)與按鈕后面兄弟節(jié)點(diǎn):
<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" >實(shí)用工具</a></li> </ul> <div id="name" > <ul class="dropdown-menu" > <li><a>關(guān)于我們</a></li> </ul> </div>
10、實(shí)現(xiàn)向上彈出子菜單,用bottom:100%(彈出子菜單bottom的定位)實(shí)現(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>
如果大家還想深入學(xué)習(xí),可以點(diǎn)擊這里進(jìn)行學(xué)習(xí),再為大家附兩個(gè)精彩的專題:Bootstrap學(xué)習(xí)教程 Bootstrap實(shí)戰(zhàn)教程
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助。
- BootStrap中關(guān)于Select下拉框選擇觸發(fā)事件及擴(kuò)展
- Bootstrap select多選下拉框?qū)崿F(xiàn)代碼
- bootstrap下拉列表與輸入框組結(jié)合的樣式調(diào)整
- Bootstrap每天必學(xué)之下拉菜單
- Bootstrap框架下下拉框select搜索功能
- Bootstrap Table 在指定列中添加下拉框控件并獲取所選值
- Bootstrap每天必學(xué)之級(jí)聯(lián)下拉菜單
- bootstrap中selectpicker下拉框使用方法實(shí)例
- Bootstrap中的Dropdown下拉菜單更改為懸停(hover)觸發(fā)
- IE11下CKEditor在Bootstrap Modal中下拉問(wèn)題的解決
相關(guān)文章
基于javascript的COOkie的操作實(shí)現(xiàn)只能點(diǎn)一次
這篇文章主要介紹了基于javascript的COOkie的操作實(shí)現(xiàn)只能點(diǎn)一次,需要的朋友可以參考下2014-12-12
原生JS實(shí)現(xiàn)的自動(dòng)輪播圖功能詳解
這篇文章主要介紹了原生JS實(shí)現(xiàn)的自動(dòng)輪播圖功能,結(jié)合實(shí)例形式詳細(xì)分析了基于原生js實(shí)現(xiàn)輪播圖的原理、操作步驟及操作注意事項(xiàng),需要的朋友可以參考下2018-12-12
用JavaScript實(shí)現(xiàn) 鐵甲無(wú)敵獎(jiǎng)門人 “開(kāi)口中”猜數(shù)游戲
JavaScript在常人看來(lái)都是門出不了廳堂的小語(yǔ)言,僅管它沒(méi)有明星語(yǔ)言的閃耀,但至少網(wǎng)頁(yè)的閃耀還是需要它的,同時(shí)它是一門很實(shí)用的語(yǔ)言。2009-10-10
把json格式的字符串轉(zhuǎn)換成javascript對(duì)象或數(shù)組的方法總結(jié)
下面小編就為大家?guī)?lái)一篇把json格式的字符串轉(zhuǎn)換成javascript對(duì)象或數(shù)組的方法總結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11
js實(shí)現(xiàn)緩沖運(yùn)動(dòng)效果的方法
這篇文章主要介紹了js實(shí)現(xiàn)緩沖運(yùn)動(dòng)效果的方法,涉及javascript操作元素運(yùn)動(dòng)的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04
詳解GoJs節(jié)點(diǎn)的選中高亮實(shí)現(xiàn)示例
這篇文章主要為大家介紹了GoJs節(jié)點(diǎn)的選中高亮實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
ts依賴引入報(bào)錯(cuò):無(wú)法找到模塊“xxxxxx”的聲明文件問(wèn)題解決
這篇文章主要給大家介紹了關(guān)于ts依賴引入報(bào)錯(cuò):無(wú)法找到模塊“xxxxxx”的聲明文件問(wèn)題的解決辦法,文中通過(guò)示例帶將解決辦法介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07
微信小程序組件復(fù)用機(jī)制behaviors示例詳解
小程序的 behaviors方法是一種代碼復(fù)用的方式,可以將一些通用的邏輯和方法提取出來(lái),然后在多個(gè)組件中復(fù)用,從而減少代碼冗余,提高代碼的可維護(hù)性,這篇文章主要介紹了微信小程序組件復(fù)用機(jī)制behaviors示例詳解,需要的朋友可以參考下2025-02-02
微信小程序的開(kāi)發(fā)范式BeautyWe.js入門詳解
這篇文章主要介紹了微信小程序的開(kāi)發(fā)范式BeautyWe.js詳解,它是一套專注于微信小程序的企業(yè)級(jí)開(kāi)發(fā)范式,它的愿景是:讓企業(yè)級(jí)的微信小程序項(xiàng)目中的代碼,更加簡(jiǎn)單、漂亮,需要的朋友可以參考下2019-07-07

