Bootstrap按鈕組件詳解
按鈕組和下拉菜單組件一樣,需要依賴于button.js插件才能正常運(yùn)作。
結(jié)構(gòu)方面:使用一個(gè)類(lèi)名為btn-group的容器,把多個(gè)按鈕放在這個(gè)容器中。
按鈕組也是一個(gè)獨(dú)立的組件,所以可以找到相應(yīng)的源碼文件:
Less:buttons.less
Sass:_buttons.scss
Css:Bootstrap.css 3131行~3291行
<div class="btn-group"> <button type="button" class="btn btn-default"> <span class="glyphicon glyphicon-step-backward"></span> </button> … <button type="button" class="btn btn-default"> <span class="glyphicon glyphicon-step-forward"></span> </button> </div>
CSS:
.btn-group, .btn-group-vertical { position: relative; display: inline-block; vertical-align: middle; } .btn-group > .btn, .btn-group-vertical > .btn { position: relative; float: left; } .btn-group > .btn:hover, .btn-group-vertical > .btn:hover, .btn-group > .btn:focus, .btn-group-vertical > .btn:focus, .btn-group > .btn:active, .btn-group-vertical > .btn:active, .btn-group > .btn.active, .btn-group-vertical > .btn.active { z-index: 2; } .btn-group > .btn:focus, .btn-group-vertical > .btn:focus { outline: none; } .btn-group .btn + .btn, .btn-group .btn + .btn-group, .btn-group .btn-group + .btn, .btn-group .btn-group + .btn-group { margin-left: -1px; }
除了可以使用<button>元素之外,還可以使用其他標(biāo)簽元素,比如<a>標(biāo)簽,唯一要保證的是:不管使用什么標(biāo)簽,.btn-group容器里的標(biāo)簽元素需要帶有類(lèi)名.btn
按鈕組四個(gè)角都是圓角,除了第一個(gè)和最后一個(gè)按鈕具有邊上的圓角外,其他的按鈕沒(méi)有圓角。
詳解:
1、默認(rèn):所有按鈕都是圓角
2、除第一個(gè)按鈕和最后一個(gè)按鈕,其他的按鈕圓角取消
3、最后一個(gè)按鈕只留右上角和右下角為圓角
源碼:
.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) { border-radius: 0; } .btn-group > .btn:first-child { margin-left: 0; } .btn-group > .btn:first-child:not(:last-child):not(.dropdown-toggle) { border-top-right-radius: 0; border-bottom-right-radius: 0; } .btn-group > .btn:last-child:not(:first-child), .btn-group > .dropdown-toggle:not(:first-child) { border-top-left-radius: 0; border-bottom-left-radius: 0; } .btn-group > .btn-group { float: left; } .btn-group > .btn-group:not(:first-child):not(:last-child) > .btn { border-radius: 0; } .btn-group > .btn-group:first-child> .btn:last-child, .btn-group > .btn-group:first-child> .dropdown-toggle { border-top-right-radius: 0; border-bottom-right-radius: 0; } .btn-group > .btn-group:last-child> .btn:first-child { border-top-left-radius: 0; border-bottom-left-radius: 0; }
按鈕組工具欄
在富文本編輯器中,將按鈕組分組排列在一起,比如說(shuō)復(fù)制,剪切,粘貼一組,左對(duì)齊,中間對(duì)齊,右對(duì)齊和兩端對(duì)齊一組,這時(shí)需要用到bootstrap框架按鈕工具欄btn-toolbar
<div class="btn-toolbar"> <div class="btn-group"> … </div> <div class="btn-group"> … </div> <div class="btn-group"> … </div> <div class="btn-group"> … </div> </div>
原理:主要是讓容器的多個(gè)分組.btn-group元素進(jìn)行浮動(dòng),并且組與組之間保持5px的左外距
.btn-toolbar { margin-left: -5px; } .btn-toolbar .btn-group, .btn-toolbar .input-group { float: left; } .btn-toolbar > .btn, .btn-toolbar > .btn-group, .btn-toolbar > .input-group { margin-left: 5px; }
注意在btn-toolbar上清除浮動(dòng)
.btn-toolbar:before, .btn-toolbar:after{ display: table; content: " "; } .btn-toolbar:after{ clear: both; }
示例:
<div class="btn-toolbar"> <div class="btn-group"> <button class="btn btn-default" type="button"> <span class="glyphicon glyphicon-align-left"></span> </button> <button class="btn btn-default" type="button"> <span class="glyphicon glyphicon-align-center"></span> </button> <button class="btn btn-default"> <span class="glyphicon glyphicon-align-right"></span> </button> <button class="btn btn-default" type="button"> <span class="glyphicon glyphicon-align-justify"></span> </button> </div> <div class="btn-group"> <button class="btn btn-default" type="button"> <span class="glyphicon glyphicon-font"></span> </button> <button class="btn btn-default" type="button"> <span class="glyphicon glyphicon-bold"></span> </button> </div> </div>
按鈕嵌套分組
很多時(shí)候,我們把下拉菜單很普通的按鈕組排列在一起,實(shí)現(xiàn)類(lèi)似于導(dǎo)航菜單的效果:
使用的時(shí)候只需將之前制作下拉菜單的dropdown容器的類(lèi)名換成btn-group,并且和普通的按鈕放在同一級(jí):
<div class="btn-group"> <button class="btn btn-default" type="button">首頁(yè)</button> <button class="btn btn-default" type="button">產(chǎn)品展示</button> <button class="btn btn-default" type="button">案例分析</button> <button class="btn btn-default" type="button">聯(lián)系我們</button> <div class="btn-group"> <button class="btn btn-default dropdown-toggle" data-toggle="dropdown" type="button"> 關(guān)于我們<span class="caret"></span> </button> <ul class="dropdown-menu"> <li><a href="#">公司簡(jiǎn)介</a></li> <li><a href="#">企業(yè)文化</a></li> <li><a href="#">組織結(jié)構(gòu)</a></li> <li><a href="#">客服服務(wù)</a></li> </ul> </div> </div> .btn-group > .btn-group { float: left; } .btn-group > .btn-group:not(:first-child):not(:last-child) > .btn { border-radius: 0; } .btn-group > .btn-group:first-child> .btn:last-child, .btn-group > .btn-group:first-child> .dropdown-toggle { border-top-right-radius: 0; border-bottom-right-radius: 0; } .btn-group > .btn-group:last-child> .btn:first-child { border-top-left-radius: 0; border-bottom-left-radius: 0; } .btn-group .dropdown-toggle:active, .btn-group.open .dropdown-toggle { outline: 0; } .btn-group > .btn + .dropdown-toggle { padding-right: 8px; padding-left: 8px; } .btn-group > .btn-lg + .dropdown-toggle { padding-right: 12px; padding-left: 12px; } .btn-group.open .dropdown-toggle { -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125); box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125); } .btn-group.open .dropdown-toggle.btn-link { -webkit-box-shadow: none; box-shadow: none; }
按鈕垂直分組
只需把水平分組的類(lèi)名.btn-group換成.btn-group-vertical即可。
<div class="btn-group-vertical"> <button class="btn btn-default" type="button">首頁(yè)</button> <button class="btn btn-default" type="button">產(chǎn)品展示</button> <button class="btn btn-default" type="button">案例分析</button> <button class="btn btn-default" type="button">聯(lián)系我們</button> <div class="btn-group"> <button class="btn btn-default dropdown-toggle" data-toggle="dropdown" type="button"> 關(guān)于我們<span class="caret"></span> </button> <ul class="dropdown-menu"> <li><a href="#">公司簡(jiǎn)介</a></li> <li><a href="#">企業(yè)文化</a></li> <li><a href="#">組織結(jié)構(gòu)</a></li> <li><a href="#">客服服務(wù)</a></li> </ul> </div> </div> .btn-group-vertical > .btn, .btn-group-vertical > .btn-group, .btn-group-vertical > .btn-group > .btn { display: block; float: none; width: 100%; max-width: 100%; } .btn-group-vertical > .btn-group > .btn { float: none; } .btn-group-vertical > .btn + .btn, .btn-group-vertical > .btn + .btn-group, .btn-group-vertical > .btn-group + .btn, .btn-group-vertical > .btn-group + .btn-group { margin-top: -1px; margin-left: 0; } .btn-group-vertical > .btn:not(:first-child):not(:last-child) { border-radius: 0; } .btn-group-vertical > .btn:first-child:not(:last-child) { border-top-right-radius: 4px; border-bottom-right-radius: 0; border-bottom-left-radius: 0; } .btn-group-vertical > .btn:last-child:not(:first-child) { border-top-left-radius: 0; border-top-right-radius: 0; border-bottom-left-radius: 4px; } .btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn { border-radius: 0; } .btn-group-vertical > .btn-group:first-child:not(:last-child) > .btn:last-child, .btn-group-vertical > .btn-group:first-child:not(:last-child) > .dropdown-toggle { border-bottom-right-radius: 0; border-bottom-left-radius: 0; } .btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child { border-top-left-radius: 0; border-top-right-radius: 0; }
等分按鈕又稱(chēng)為自適應(yīng)分組按鈕:
整個(gè)按鈕組的寬度是容器的100%,而按鈕組里面的每個(gè)按鈕平分整個(gè)容器的寬度,例如一個(gè)按鈕組里有五個(gè)按鈕,每個(gè)按鈕是容器寬度的20%;一個(gè)按鈕組里有四個(gè)按鈕,每個(gè)按鈕是容器寬度的25%;
實(shí)現(xiàn)方法:只需要在按鈕組.btn-group 上追加一個(gè)類(lèi)名.btn-group-justified
<div class="btn-group btn-group-justified"> <buttton class="btn btn-default" type="button">首頁(yè)</buttton> <buttton class="btn btn-default" type="button">案例分析</buttton> <buttton class="btn btn-default" type="button">聯(lián)系我們</buttton> <buttton class="btn btn-default" type="button">關(guān)于我們</buttton> </div> .btn-group-justified { display: table; width: 100%; table-layout: fixed; border-collapse: separate; } .btn-group-justified > .btn, .btn-group-justified > .btn-group { display: table-cell; float: none; width: 1%; } .btn-group-justified > .btn-group .btn { width: 100%; }
把.btn-group-justified模擬成表格(display:table),并且把里面的按鈕模板模擬成表格單元格(display:table-cell)。
注意:在制作等分按鈕組時(shí),盡量使用<a>標(biāo)簽來(lái)制作按鈕,因?yàn)槭褂胋utton標(biāo)簽元素時(shí),使用display:table在部分瀏覽器下支持并不友好
腳本之家推薦閱讀:
以上所述是小編給大家介紹的Bootstrap按鈕組件,希望對(duì)大家有所幫助!
相關(guān)文章
Three光源Target位置改變光照方向不變的問(wèn)題解決方法
這篇文章主要為大家介紹了Three光源Target位置改變光照方向不變的問(wèn)題及解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12微信小程序?qū)崿F(xiàn)錄音時(shí)的麥克風(fēng)動(dòng)畫(huà)效果實(shí)例
這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崿F(xiàn)錄音時(shí)的麥克風(fēng)動(dòng)畫(huà)效果的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用微信小程序具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05turn.js異步加載實(shí)現(xiàn)翻書(shū)效果
這篇文章主要為大家詳細(xì)介紹了turn.js異步加載實(shí)現(xiàn)翻書(shū)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07js 對(duì)小數(shù)加法精度處理示例說(shuō)明
javascript的加法結(jié)果會(huì)有誤差,在兩個(gè)浮點(diǎn)數(shù)相加的時(shí)候會(huì)比較明顯。這個(gè)函數(shù)返回較為精確的加法結(jié)果,下面為大家介紹下js如何對(duì)小數(shù)加法精度處理2013-12-12uni-app常用的幾種頁(yè)面跳轉(zhuǎn)方式總結(jié)
uni-app的頁(yè)面跳轉(zhuǎn)和小程序和vue很相似,只是方法和標(biāo)簽有所不同,這篇文章主要給大家介紹了關(guān)于uni-app常用的幾種頁(yè)面跳轉(zhuǎn)方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08js 實(shí)現(xiàn)在2d平面上畫(huà)8的方法
今天小編就為大家分享一篇js 實(shí)現(xiàn)在2d平面上畫(huà)8的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10