下拉菜单

  1. <div class="dropdown">
  2. <button class="btn btn-default dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown">
  3. 下拉菜单
  4. <span class="caret"></span>
  5. </button>
  6. <ul class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu1">
  7. <li role="presentation"><a role="menuitem" tabindex="-1" href="#">下拉菜单项</a></li>

  8. <li role="presentation" class="divider"></li>
  9. <li role="presentation"><a role="menuitem" tabindex="-1" href="#">下拉菜单项</a></li>
  10. </ul>
  11. </div>

示例

  1. .dropdown-menu {
  2. position: absolute;/*设置绝对定位,相对于父元素div.dropdown*/
  3. top: 100%;/*让下拉菜单项在父菜单项底部,如果父元素不设置相对定位,该元素相对于body元素*/
  4. left: 0;
  5. z-index: 1000;/*让下拉菜单项不被其他元素遮盖住*/
  6. display: none;/*默认隐藏下拉菜单项*/
  7. float: left;
  8. min-width: 160px;
  9. padding: 5px 0;
  10. margin: 2px 0 0;
  11. font-size: 14px;
  12. list-style: none;
  13. background-color: #fff;
  14. background-clip: padding-box;
  15. border: 1px solid #ccc;
  16. border: 1px solid rgba(0, 0, 0, .15);
  17. border-radius: 4px;
  18. -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, .175);
  19. box-shadow: 0 6px 12px rgba(0, 0, 0, .175);
  20. }
  21.  
  22. //通过点击调用js添加或移除js
  23. .open > .dropdown-menu {
  24. display: block;
  25. }
  26.  
  27. 源码分析

示例

下拉分割线:添加一个空的<li>,并且给这个<li>添加类名“divider”

  1. .dropdown-menu .divider {
  2. height: 1px;
  3. margin: 9px 0;
  4. overflow: hidden;
  5. background-color: #e5e5e5;
  6. }
  7.  
  8. 源码

示例

下拉菜单标题:  class="dropdown-header"

  1. <div class="dropdown">
  2. <button class="btn btn-default dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown">
  3. 下拉菜单
  4. <span class="caret"></span>
  5. </button>
  6. <ul class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu1">
  7. <li role="presentation" class="dropdown-header">第一部分菜单头部</li>
  8. <li role="presentation"><a role="menuitem" tabindex="-1" href="#">下拉菜单项</a></li>

  9. <li role="presentation" class="divider"></li>
  10. <li role="presentation" class="dropdown-header">第二部分菜单头部</li>

  11. <li role="presentation"><a role="menuitem" tabindex="-1" href="#">下拉菜单项</a></li>
  12. </ul>
  13. </div>
  14.  
  15. .dropdown-header {
  16. display: block;
  17. padding: 3px 20px;
  18. font-size: 12px;
  19. line-height: 1.42857143;
  20. color: #999;
  21. }

示例

              

下拉菜单(对齐方式):在“dropdown-menu”上添加一个“pull-right”或者“dropdown-menu-right”类名

  1. <div class="dropdown">
  2. <button class="btn btn-default dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown">
  3. 下拉菜单
  4. <span class="caret"></span>
  5. </button>
  6. <ul class="dropdown-menu pull-right" role="menu" aria-labelledby="dropdownMenu1">

  7. </ul>
  8. </div>
  9.  
  10. 源码
  11. .dropdown-menu.pull-right {
  12. right: 0;
  13. left: auto;
  14. }
  15. .dropdown-menu-right {
  16. right: 0;
  17. left: auto;
  18. }
  19. 同时一定要为.dropdown添加float:leftcss样式。
  20. .dropdown{
  21. float: left;
  22. }

示例+源码

下拉菜单(菜单项状态):class="active"、class="disabled"

  1. <div class="dropdown">
  2. <button class="btn btn-default dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown">
  3. 下拉菜单
  4. <span class="caret"></span>
  5. </button>
  6. <ul class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu1">
  7. <li role="presentation" class="active"><a role="menuitem" tabindex="-1" href="#">下拉菜单项</a></li>
  8. ….
  9. <li role="presentation" class="disabled"><a role="menuitem" tabindex="-1" href="#">下拉菜单项</a></li>
  10. </ul>
  11. </div>
  12.  
  13. //源码
  14. .dropdown-menu > .active > a,
  15. .dropdown-menu > .active > a:hover,
  16. .dropdown-menu > .active > a:focus {
  17. color: #fff;
  18. text-decoration: none;
  19. background-color: #428bca;
  20. outline: 0;
  21. }
  22. .dropdown-menu > .disabled > a,
  23. .dropdown-menu > .disabled > a:hover,
  24. .dropdown-menu > .disabled > a:focus {
  25. color: #999;
  26. }
  27. .dropdown-menu > .disabled > a:hover,
  28. .dropdown-menu > .disabled > a:focus {
  29. text-decoration: none;
  30. cursor: not-allowed;
  31. background-color: transparent;
  32. background-image: none;
  33. filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
  34. }

示例

按钮

按钮组  类名btn-group

  1. <div class="btn-group">
  2. <button type="button" class="btn btn-default">
  3. <span class="glyphicon glyphicon-step-backward"></span>
  4. </button>

  5. <button type="button" class="btn btn-default">
  6. <span class="glyphicon glyphicon-step-forward"></span>
  7. </button>
  8. </div>
  9.  
  10. 源码
  11. .btn-group,
  12. .btn-group-vertical {
  13. position: relative;
  14. display: inline-block;
  15. vertical-align: middle;
  16. }
  17. .btn-group > .btn,
  18. .btn-group-vertical > .btn {
  19. position: relative;
  20. float: left;
  21. }
  22. .btn-group > .btn:hover,
  23. .btn-group-vertical > .btn:hover,
  24. .btn-group > .btn:focus,
  25. .btn-group-vertical > .btn:focus,
  26. .btn-group > .btn:active,
  27. .btn-group-vertical > .btn:active,
  28. .btn-group > .btn.active,
  29. .btn-group-vertical > .btn.active {
  30. z-index: 2;
  31. }
  32. .btn-group > .btn:focus,
  33. .btn-group-vertical > .btn:focus {
  34. outline: none;
  35. }
  36. .btn-group .btn + .btn,
  37. .btn-group .btn + .btn-group,
  38. .btn-group .btn-group + .btn,
  39. .btn-group .btn-group + .btn-group {
  40. margin-left: -1px;
  41. }
  42.  
  43. 1、默认所有按钮都有圆角
  44. 2、除第一个按钮和最后一个按钮(下拉按钮除外),其他的按钮都取消圆角效果
  45. 3、第一个按钮只留左上角和左下角是圆角
  46. 4、最后一个按钮只留右上角和右下角是圆角
  47. 对应的源码如下:
  48. .btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {
  49. border-radius: 0;
  50. }
  51. .btn-group > .btn:first-child {
  52. margin-left: 0;
  53. }
  54. .btn-group > .btn:first-child:not(:last-child):not(.dropdown-toggle) {
  55. border-top-right-radius: 0;
  56. border-bottom-right-radius: 0;
  57. }
  58. .btn-group > .btn:last-child:not(:first-child),
  59. .btn-group > .dropdown-toggle:not(:first-child) {
  60. border-top-left-radius: 0;
  61. border-bottom-left-radius: 0;
  62. }
  63. .btn-group > .btn-group {
  64. float: left;
  65. }
  66. .btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {
  67. border-radius: 0;
  68. }
  69. .btn-group > .btn-group:first-child> .btn:last-child,
  70. .btn-group > .btn-group:first-child> .dropdown-toggle {
  71. border-top-right-radius: 0;
  72. border-bottom-right-radius: 0;
  73. }
  74. .btn-group > .btn-group:last-child> .btn:first-child {
  75. border-top-left-radius: 0;
  76. border-bottom-left-radius: 0;
  77. }

示例

按钮(按钮工具栏) 类名btn-toolbar

.btn-group-lg:大按钮组   .btn-group-sm:小按钮组   .btn-group-xs:超小按钮组

  1. <div class="btn-toolbar">
  2. <div class="btn-group">

  3. </div>
  4. <div class="btn-group">

  5. </div>
  6. <div class="btn-group">

  7. </div>
  8. <div class="btn-group">

  9. </div>
  10. </div>
  11.  
  12. 源码
  13. .btn-toolbar {
  14. margin-left: -5px;
  15. }
  16. .btn-toolbar .btn-group,
  17. .btn-toolbar .input-group {
  18. float: left;
  19. }
  20. .btn-toolbar > .btn,
  21. .btn-toolbar > .btn-group,
  22. .btn-toolbar > .input-group {
  23. margin-left: 5px;
  24. }
  25.  
  26. 注意在”btn-toolbar”上清除浮动。
  27. .btn-toolbar:before,
  28. .btn-toolbar:after{
  29.  display: table;
  30. content: " ";

  31. .btn-toolbar:after{
  32. clear: both;
  33. }

示例

按钮(嵌套分组): “btn-group”和普通的按钮放在同一级。

  1. <div class="btn-group">
  2. <button class="btnbtn-default" type="button">首页</button>
  3. <button class="btnbtn-default" type="button">产品展示</button>
  4. <button class="btnbtn-default" type="button">案例分析</button>
  5. <button class="btnbtn-default" type="button">联系我们</button>
  6. <div class="btn-group">
  7. <button class="btnbtn-default dropdown-toggle" data-toggle="dropdown" type="button">关于我们<span class="caret"></span></button>
  8. <ul class="dropdown-menu">
  9. <li><a href="##">公司简介</a></li>
  10. <li><a href="##">企业文化</a></li>
  11. <li><a href="##">组织结构</a></li>
  12. <li><a href="##">客服服务</a></li>
  13. </ul>
  14. </div>
  15. </div>
  16.  
  17. 源码
  18. .btn-group > .btn-group {
  19. float: left;
  20. }
  21. .btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {
  22. border-radius: 0;
  23. }
  24. .btn-group > .btn-group:first-child> .btn:last-child,
  25. .btn-group > .btn-group:first-child> .dropdown-toggle {
  26. border-top-right-radius: 0;
  27. border-bottom-right-radius: 0;
  28. }
  29. .btn-group > .btn-group:last-child> .btn:first-child {
  30. border-top-left-radius: 0;
  31. border-bottom-left-radius: 0;
  32. }
  33. .btn-group .dropdown-toggle:active,
  34. .btn-group.open .dropdown-toggle {
  35. outline: 0;
  36. }
  37. .btn-group > .btn + .dropdown-toggle {
  38. padding-right: 8px;
  39. padding-left: 8px;
  40. }
  41. .btn-group > .btn-lg + .dropdown-toggle {
  42. padding-right: 12px;
  43. padding-left: 12px;
  44. }
  45. .btn-group.open .dropdown-toggle {
  46. -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
  47. box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
  48. }
  49. .btn-group.open .dropdown-toggle.btn-link {
  50. -webkit-box-shadow: none;
  51. box-shadow: none;
  52. }

示例

按钮(垂直分组):类名“btn-group-vertical”

  1. <div class="btn-group-vertical">
  2. <button class="btnbtn-default" type="button">首页</button>
  3. <button class="btnbtn-default" type="button">产品展示</button>
  4. <button class="btnbtn-default" type="button">案例分析</button>
  5. <button class="btnbtn-default" type="button">联系我们</button>
  6. <div class="btn-group">
  7. <button class="btn btn-default dropdown-toggle" data-toggle="dropdown" type="button">关于我们<span class="caret"></span></button>
  8. <ul class="dropdown-menu">
  9. <li><a href="##">公司简介</a></li>
  10. <li><a href="##">企业文化</a></li>
  11. <li><a href="##">组织结构</a></li>
  12. <li><a href="##">客服服务</a></li>
  13. </ul>
  14. </div>
  15. </div>
  16.  
  17. 源码
  18. .btn-group-vertical > .btn,
  19. .btn-group-vertical > .btn-group,
  20. .btn-group-vertical > .btn-group > .btn {
  21. display: block;
  22. float: none;
  23. width: 100%;
  24. max-width: 100%;
  25. }
  26. .btn-group-vertical > .btn-group > .btn {
  27. float: none;
  28. }
  29. .btn-group-vertical > .btn + .btn,
  30. .btn-group-vertical > .btn + .btn-group,
  31. .btn-group-vertical > .btn-group + .btn,
  32. .btn-group-vertical > .btn-group + .btn-group {
  33. margin-top: -1px;
  34. margin-left: 0;
  35. }
  36. .btn-group-vertical > .btn:not(:first-child):not(:last-child) {
  37. border-radius: 0;
  38. }
  39. .btn-group-vertical > .btn:first-child:not(:last-child) {
  40. border-top-right-radius: 4px;
  41. border-bottom-right-radius: 0;
  42. border-bottom-left-radius: 0;
  43. }
  44. .btn-group-vertical > .btn:last-child:not(:first-child) {
  45. border-top-left-radius: 0;
  46. border-top-right-radius: 0;
  47. border-bottom-left-radius: 4px;
  48. }
  49. .btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {
  50. border-radius: 0;
  51. }
  52. .btn-group-vertical > .btn-group:first-child:not(:last-child) > .btn:last-child,
  53. .btn-group-vertical > .btn-group:first-child:not(:last-child) > .dropdown-toggle {
  54. border-bottom-right-radius: 0;
  55. border-bottom-left-radius: 0;
  56. }
  57. .btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {
  58. border-top-left-radius: 0;
  59. border-top-right-radius: 0;

示例

                    

按钮(等分按钮) “btn-group-justified”类名

  1. 特别声明:在制作等分按钮组时,请尽量使用<a>标签元素来制作按钮,因为使用<button>标签元素时,使用display:table在部分浏览器下支持并不友好。
  2. <div class="btn-wrap">
  3. <div class="btn-group btn-group-justified">
  4. <a class="btnbtn-default" href="#">首页</a>
  5. <a class="btnbtn-default" href="#">产品展示</a>
  6. <a class="btnbtn-default" href="#">案例分析</a>
  7. <a class="btnbtn-default" href="#">联系我们</a>
  8. </div>
  9. </div>
  10.  
  11. 源码
  12. .btn-group-justified {
  13. display: table;
  14. width: 100%;
  15. table-layout: fixed;
  16. border-collapse: separate;
  17. }
  18. .btn-group-justified > .btn,
  19. .btn-group-justified > .btn-group {
  20. display: table-cell;
  21. float: none;
  22. width: 1%;
  23. }
  24. .btn-group-justified > .btn-group .btn {
  25. width: 100%;
  26. }

示例

按钮下拉菜单

  1. 按钮下拉菜单从外观上看和下拉菜单效果基本上是一样的;简单点说就是点击一个按钮,会显示隐藏的下拉菜单
  2. <div class="btn-group">
  3. <button class="btn btn-default dropdown-toggle" data-toggle="dropdown" type="button">按钮下拉菜单<span class="caret"></span></button>
  4. <ul class="dropdown-menu">
  5. <li><a href="##">按钮下拉菜单项</a></li>
  6. <li><a href="##">按钮下拉菜单项</a></li>
  7. <li><a href="##">按钮下拉菜单项</a></li>
  8. <li><a href="##">按钮下拉菜单项</a></li>
  9. </ul>
  10. </div>
  11.  
  12. 源码:
  13. .btn-group .dropdown-toggle:active,
  14. .btn-group.open .dropdown-toggle {
  15. outline: 0;
  16. }
  17. .btn-group > .btn + .dropdown-toggle {
  18. padding-right: 8px;
  19. padding-left: 8px;
  20. }
  21. .btn-group > .btn-lg + .dropdown-toggle {
  22. padding-right: 12px;
  23. padding-left: 12px;
  24. }
  25. .btn-group.open .dropdown-toggle {
  26. -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
  27. box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
  28. }
  29. .btn-group.open .dropdown-toggle.btn-link {
  30. -webkit-box-shadow: none;
  31. box-shadow: none;
  32. }

示例

按钮的向下向上三角形   类名.dropup向上

  1. <div class="btn-group dropup">
  2. <button class="btn btn-default dropdown-toggle" data-toggle="dropdown" type="button">按钮下拉菜单<span class="caret"></span></button>
  3. <ul class="dropdown-menu">
  4. <li><a href="##">按钮下拉菜单项</a></li>
  5. <li><a href="##">按钮下拉菜单项</a></li>
  6. <li><a href="##">按钮下拉菜单项</a></li>
  7. <li><a href="##">按钮下拉菜单项</a></li>
  8. </ul>
  9. </div>
  10.  
  11. 解析
  12. 按钮的向下三角形,我们是通过在<button>标签中添加一个“<span>”标签元素,并且命名为“caret”:
  13. <button class="btn btn-default dropdown-toggle" data-toggle="dropdown" type="button">按钮下拉菜单<span class="caret"></span></button>
  14.  
  15. 源码:
  16. .caret { //生成三角形
  17. display: inline-block;
  18. width: 0;
  19. height: 0;
  20. margin-left: 2px;
  21. vertical-align: middle;
  22. border-top: 4px solid;
  23. border-right: 4px solid transparent;
  24. border-left: 4px solid transparent;
  25. }
  26.  
  27. 在按钮中的三角形“caret”做了一定的样式处理:
  28. .btn .caret {
  29. margin-left: 0;
  30. }
  31. .btn-lg .caret {
  32. border-width: 5px 5px 0;
  33. border-bottom-width: 0;
  34. }
  35. .dropup .btn-lg .caret {
  36. border-width: 0 5px 5px;
  37. }
  38.  
  39. 向上三角与向下三角的区别:其实就是改变了一个border-bottom的值。
  40. .dropup .caret,
  41. .navbar-fixed-bottom .dropdown .caret {
  42. content: "";
  43. border-top: 0;
  44. border-bottom: 4px solid;
  45. }

示例

bootstrap学习笔记(菜单.按钮)的更多相关文章

  1. bootstrap学习笔记细化(按钮)

    button:btn 圆角灰色按钮 button:btn btn-default 圆角灰色边框按钮 button:btn btn-success 绿色 button:btn btn-primary 蓝 ...

  2. Bootstrap 学习笔记11 按钮和折叠插件

     复选框: <div class="btn-group" data-toggle="buttons"> <label for="se ...

  3. bootstrap学习笔记之为导航条添加标题、二级菜单及状态 http://www.imooc.com/code/3120

    为导航条添加标题.二级菜单及状态 加入导航条标题 在Web页面制作中,常常在菜单前面都会有一个标题(文字字号比其它文字稍大一些),其实在Bootstrap框架也为大家做了这方面考虑,其通过" ...

  4. Bootstrap学习笔记(二) 表单

    在Bootstrap学习笔记(一) 排版的基础上继续学习Bootstrap的表单,编辑器及head内代码不变. 3-1 基础表单 单中常见的元素主要包括:文本输入框.下拉选择框.单选按钮.复选按钮.文 ...

  5. bootstrap学习笔记之基础导航条 http://www.imooc.com/code/3111

    基础导航条 在Bootstrap框中,导航条和导航从外观上差别不是太多,但在实际使用中导航条要比导航复杂得多.我们先来看导航条中最基础的一个--基础导航条. 使用方法: 在制作一个基础导航条时,主要分 ...

  6. Bootstrap~学习笔记索引

    回到占占推荐博客索引 bootstrap已经用了有段时间了,感觉在使用上还是比较容易接受的,在开发人员用起来上,也还好,不用考虑它的兼容性,手机,平台,PC都可以有效的兼容. bootstrap官方a ...

  7. Bootstrap学习笔记-布局

    Bootstrap学习笔记-布局 默认是响应式布局,就是你在改变页面的时候也不会出现乱的现象. <html><head> <meta charset="utf- ...

  8. Bootstrap学习笔记(5)--实现Bootstrap导航条可点击和鼠标悬停显示下拉菜单

    实现Bootstrap导航条可点击和鼠标悬停显示下拉菜单 微笑的鱼 2014-01-03 Bootstrap 5,281 次围观 11条评论 使用Bootstrap导航条组件时,如果你的导航条带有下拉 ...

  9. Bootstrap学习笔记博客

    本片博客用于记录之后要用到Bootstrap的学习笔记   概括: Bootstrap 是一个用于快速开发 Web 应用程序和网站的前端框架.Bootstrap 是基于 HTML.CSS.JAVASC ...

随机推荐

  1. iOS学习笔记(5)——显示简单的TableView

    1. 创建工程 创建一个新的Xcode工程命名为SimpleTableTest. 删除main.storyboard文件和info.plist中有关storyboard的相关属性. 按command+ ...

  2. 0、weka学习与使用

    转载自:https://blog.csdn.net/u011067360/article/details/20844443 数据挖掘开源软件:WEKA基础教程 本文档部分来自于网络,随着自己的深入学习 ...

  3. jinja url_for js 参数

    在JavaScript中,也就是客户端,向flask路由服务器端使用post请求并在url_for中传递参数,服务器端获取不到该参数, Jinja不能使用Javascript变量,如下所示: var ...

  4. mysql:服务器错误代码

    服务器错误代码和消息 原文:https://dev.mysql.com/doc/refman/5.7/en/error-messages-server.html MySQL的程序有几种类型的错误信息时 ...

  5. Android版本信息及与Linux和Java的关系

    1.Android与Linux和Java的关系 Android严格来说,不能算是Linux,Android是一个统称,具体来说,是Google用了Linux的一个核心,用这个核心来管理进程,控制硬件. ...

  6. 安装Ubunutu音频视频库

    sudo apt-get install ubuntu-restricted-extras

  7. win7下安装centos6.5后,开机无法进入选择双系统启动界面,只能启动centos的解决办法

    1.centos6.5下打开终端,进入/boot/grub ,vim grub.conf 将default=0 改为1,重启 2.重启后,又只能进入win7了.这个好解决.下载一个easyBCD,具体 ...

  8. Kubernetes是什么

    目录 简介 主要概念: 总体结构 参考 Kubernetes概念 简介 kubernetes是一个Google开源的容器编排系统,用于自动部署,扩展和管理容器化应用程序. 随处运行:支持公有云,私有云 ...

  9. CADisplayLink+弹簧动画实现果冻效果

    项目中在Tabbar中间的按钮要从底部弹出视图并有果冻效果,在CocoaChina中找了一篇博客用 UIBezierPath 实现果冻效果,github,自己就按着上面的demo修改了一下( 之前也是 ...

  10. CSS3 Media Queries_media queries, css3属性详解

    Media Queries直译过来就是"媒体查询",在我们平时的Web页面中head部分常看到这样的一段代码: <link href="css/reset.css& ...