Bootstrap每天必学之导航组件


Posted in Javascript onApril 25, 2016

在bootstrap框架中将导航独立出来成为一个导航组件,根据不同的版本,可以找到相应的源码:

LESS:  navs.less

SASS:  _navs.scss 

标签形导航,也称选项卡导航

标签形导航是通过.nav-tabs样式来实现的,在制作标签形导航时需要在原导航类名为.nav的容器上追加类名.nav-tabs

<ul class="nav nav-tabs">
  <li><a href="#">导航标题1</a></li>
  <li><a href="#">导航标题2</a></li>
  <li><a href="#">导航标题3</a></li>
  <li><a href="#">导航标题4</a></li>
  <li><a href="#">导航标题5</a></li>
 </ul>

原理:

将菜单项li按块显示,并让它们排列在同一水平上,然后定义非高亮菜单的样式和鼠标悬浮效果

.nav-tabs {
border-bottom: 1px solid #ddd;
}
.nav-tabs > li {
float: left;
margin-bottom: -1px;
}
.nav-tabs > li > a {
margin-right: 2px;
line-height: 1.42857143;
border: 1px solid transparent;
border-radius: 4px 4px 0 0;
}
.nav-tabs > li >a:hover {
border-color: #eee #eee #ddd;
}

一般情况下,选项卡都会有个当前选中项,只需要在其(li)标签上添加类名.active即可

<ul class="nav nav-tabs">
  <li class="active"><a href="#">导航标题1</a></li>
  <li><a href="#">导航标题2</a></li>
  <li><a href="#">导航标题3</a></li>
  <li><a href="#">导航标题4</a></li>
  <li><a href="#">导航标题5</a></li>
</ul>
.nav-tabs >li.active> a,
.nav-tabs >li.active>a:hover,
.nav-tabs >li.active>a:focus {
 color: #555;
 cursor: default;
 background-color: #fff;
 border: 1px solid #ddd;
 border-bottom-color: transparent;
}

除了当前选项外,有的选项卡还带有禁用状态,实现这样的效果,只需在标签项上添加类名disabled

.nav>li.disabled> a {
 color: #999;
}
.nav>li.disabled>a:hover,
.nav>li.disabled>a:focus {
 color: #999;
 text-decoration: none;
 cursor: not-allowed;
 background-color: transparent;
}

如果要实现点击菜单项就可以切换内容的效果,就需要配合js插件

胶囊形(pills)导航

当前高亮显示,并带圆角效果,其实现方法和选项卡导航类似,同样的结构,只需将类名.nav-tabs换成类名.nav-pills

.nav-pills > li {
 float: left;
}
.nav-pills > li > a {
 border-radius: 4px;
}
.nav-pills > li + li {
 margin-left: 2px;
}
.nav-pills >li.active> a,
.nav-pills >li.active>a:hover,
.nav-pills >li.active>a:focus {
color: #fff;
 background-color: #428bca;
}

垂直堆叠的导航

除了水平导航,还有垂直导航,制作垂直堆叠的导航只需在.nav-pills的基础上追加类名.nav-stacked

与胶囊形导航相比,主要是让导航项不浮动,让其垂直排列,然后给相邻导航项留有一定的间距

.nav-stacked > li {
 float: none;
}
.nav-stacked > li + li {
 margin-top: 2px;
 margin-left: 0;
}

<ul class="nav nav-pills nav-stacked">
  <li><a href="#">导航标题0</a></li>
  <li class="active"><a href="#">导航标题1</a></li>
  <li><a href="#">导航标题2</a></li>
  <li><a href="#">导航标题3</a></li>
  <li><a href="#">导航标题4</a></li>
  <li class="disabled"><a href="#">导航标题5</a></li>
</ul>

垂直堆叠导航像下拉菜单组与组间有一分割线一样,导航项之间也有分割线这样的效果,只需在导航项之间添加<li class=”divider”></li>

<ul class="nav nav-pills nav-stacked">
  <li ><a href="#">导航标题0</a></li>
  <li class="active"><a href="#">导航标题1</a></li>
  <li><a href="#">导航标题2</a></li>
  <li class="nav-divider"></li>
  <li><a href="#">导航标题3</a></li>
  <li><a href="#">导航标题4</a></li>
  <li class="disabled"><a href="#">导航标题5</a></li>
 </ul>
.nav .nav-divider {
height: 1px;
margin: 9px 0;
overflow: hidden;
background-color: #e5e5e5;
}

自适应导航

自适应导航指的是导航占据容器全部宽度,而且菜单项可以像表格的单元格一样自适应宽度,自适应导航和之前提到的.btn-group-justified制作的自适应按钮组件一样,不过在制作自适应导航时类名.nav-justified需和.nav-tabs或.nav-pills配合一起使用

原理:

列表ul上设置宽度为100%,然后每个菜单项li设置了display:table-cell,让列表模拟表格单元格的形式显示;

.nav-justified {
 width: 100%;
}
.nav-justified > li {
 float: none;
}
.nav-justified > li > a {
 margin-bottom: 5px;
 text-align: center;
}
.nav-justified > .dropdown .dropdown-menu {
 top: auto;
 left: auto;
}
@media (min-width: 768px) {
 .nav-justified > li {
 display: table-cell;
 width: 1%;
 }
 .nav-justified > li > a {
 margin-bottom: 0;
 }
}

上面有一个媒体查询条件:@media(min-width:768px){……}表示自适应导航仅在浏览器视窗宽度大于768px才能按上面的风格显示,但浏览器视窗宽度小于768px时,会按下图的风格显示

Bootstrap每天必学之导航组件

.nav-tabs和.nav-justified配合在一起使用,也就是自适应选项卡导航,浏览器视窗宽度小于768px时,在样式上做了另外的处理

.nav-tabs.nav-justified {
 width: 100%;
 border-bottom: 0;
}
.nav-tabs.nav-justified > li {
 float: none;
}
.nav-tabs.nav-justified > li > a {
 margin-bottom: 5px;
 text-align: center;
}
.nav-tabs.nav-justified > .dropdown .dropdown-menu {
 top: auto;
 left: auto;
}
@media (min-width: 768px) {
 .nav-tabs.nav-justified > li {
 display: table-cell;
 width: 1%;
 }
.nav-tabs.nav-justified > li > a {
 margin-bottom: 0;
 }
}
.nav-tabs.nav-justified > li > a {
 margin-right: 0;
 border-radius: 4px;
}
.nav-tabs.nav-justified > .active > a,
.nav-tabs.nav-justified > .active >a:hover,
.nav-tabs.nav-justified > .active >a:focus {
 border: 1px solid #ddd;
}
@media (min-width: 768px) {
 .nav-tabs.nav-justified > li > a {
 border-bottom: 1px solid #ddd;
 border-radius: 4px 4px 0 0;
 }
.nav-tabs.nav-justified > .active > a,
.nav-tabs.nav-justified > .active >a:hover,
.nav-tabs.nav-justified > .active >a:focus {
 border-bottom-color: #fff;
 }
}

导航加下拉菜单(二级导航)

制做二级导航只需将li当做父容器,使用类名.dropdown,同时在li中嵌套另一个ul列表

<ul class="nav nav-tabs">
  <li><a href="#">导航菜单1</a></li>
  <li><a href="#">导航菜单2</a></li>
  <li><a href="#">导航菜单3</a></li>
  <li><a href="#">导航菜单4</a></li>
  <li class="dropdown">
   <a class="dropdown-toggle"data-toggle="dropdown">
    导航菜单5
    <span class="caret"></span>
   </a>
   <ul class="dropdown-menu">
    <li><a href="#">下拉菜单1</a></li>
    <li><a href="#">下拉菜单2</a></li>
    <li><a href="#">下拉菜单3</a></li>
    <li><a href="#">下拉菜单4</a></li>
   </ul>
  </li>
  <li><a href="#">导航菜单6</a></li>
 </ul>

面包屑式导航

面包屑一般用于导航,主要的作用是告诉用户现在所处页面的位置,在bootstrap框架中面包屑也是一个独立的模块组件。

LESS: breadcrumbs.less

SASS:_breadcrumbs.scss

<ol class="breadcrumb">
  <li><a href="#">首页</a></li>
  <li><a href="#">我的书</a></li>
  <li class="active">图解css</li>
 </ol>
.breadcrumb {
padding: 8px 15px;
margin-bottom: 20px;
list-style: none;
background-color: #f5f5f5;
border-radius: 4px;
}

.breadcrumb> li {
display: inline-block;
}

.breadcrumb> li + li:before {
padding: 0 5px;
color: #ccc;
content: "/\00a0";
}

.breadcrumb> .active {
color: #999;
}

上面使用li+li:before实现li与li之间的分隔符,这种方案在低版本ie不支持

如果大家还想深入学习,可以点击这里进行学习,再为大家附两个精彩的专题:Bootstrap学习教程 Bootstrap实战教程

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
jQuery powerFloat万能浮动层下拉层插件使用介绍
Dec 27 Javascript
JS鼠标滑过图片时切换图片实现思路
Sep 12 Javascript
js+css简单实现网页换肤效果
Dec 29 Javascript
JavaScript学习小结之使用canvas画“哆啦A梦”时钟
Jul 24 Javascript
AngularJS 实现JavaScript 动画效果详解
Sep 08 Javascript
学习Node.js模块机制
Oct 17 Javascript
BootStrap 下拉菜单点击之后不会出现下拉菜单(下拉菜单不弹出)的解决方案
Dec 14 Javascript
bootstrap输入框组使用方法
Feb 07 Javascript
Bootstrap fileinput文件上传预览插件使用详解
May 16 Javascript
JavaScript闭包的简单应用
Sep 01 Javascript
JS实现页面内跳转的简单代码
Sep 03 Javascript
vue 实现特定条件下绑定事件
Nov 09 Javascript
JavaScript常用字符串与数组扩展函数小结
Apr 24 #Javascript
javascript断点调试心得分享
Apr 23 #Javascript
基于 Node.js 实现前后端分离
Apr 23 #Javascript
javascript学习指南之回调问题
Apr 23 #Javascript
探寻JavaScript中this指针指向
Apr 23 #Javascript
javascript中this指向详解
Apr 23 #Javascript
JavaScript实现Base64编码转换
Apr 23 #Javascript
You might like
php的一些小问题
2010/07/03 PHP
drupal 代码实现URL重写
2011/05/04 PHP
javascript XMLHttpRequest对象全面剖析
2010/04/24 Javascript
中文字符串截取的js函数代码
2013/04/17 Javascript
JavaScript?Apple设备检测示例代码
2013/11/15 Javascript
Javascript和Java获取各种form表单信息的简单实例
2014/02/14 Javascript
js实现从数组里随机获取元素
2015/01/12 Javascript
jQuery Ajax页面局部加载方法汇总
2016/06/02 Javascript
vuejs动态组件给子组件传递数据的方法详解
2016/09/09 Javascript
jQuery Validation Engine验证控件调用外部函数验证的方法
2017/01/18 Javascript
微信小程序 参数传递实例代码
2017/03/20 Javascript
详解打造 Vue.js 可复用组件
2017/03/24 Javascript
HTML5+jQuery实现搜索智能匹配功能
2017/03/24 jQuery
浅谈nodejs中的类定义和继承的套路
2017/07/26 NodeJs
vue-cli的eslint相关用法
2017/09/29 Javascript
vue实现类似淘宝商品评价页面星级评价及上传多张图片功能
2018/10/29 Javascript
node链接mongodb数据库的方法详解【阿里云服务器环境ubuntu】
2019/03/07 Javascript
解决vue组件props传值对象获取不到的问题
2019/06/06 Javascript
Vue组件实现触底判断
2019/06/26 Javascript
详解Python的Django框架中的中间件
2015/07/24 Python
详解django中自定义标签和过滤器
2017/07/03 Python
django中的setting最佳配置小结
2017/11/21 Python
对Python 文件夹遍历和文件查找的实例讲解
2018/04/26 Python
Python对象与引用的介绍
2019/01/24 Python
django2.0扩展用户字段示例
2019/02/13 Python
numpy创建单位矩阵和对角矩阵的实例
2019/11/29 Python
浅谈SciPy中的optimize.minimize实现受限优化问题
2020/02/29 Python
Python requests模块cookie实例解析
2020/04/14 Python
django 数据库 get_or_create函数返回值是tuple的问题
2020/05/15 Python
一份比较全的PHP面试题
2016/07/29 面试题
物流经理自我评价
2013/09/23 职场文书
食堂管理制度范本
2015/08/04 职场文书
公安干警正风肃纪心得体会
2016/01/15 职场文书
SQL中的三种去重方法小结
2021/11/01 SQL Server
JavaScript 定时器详情
2021/11/11 Javascript
如何用六步教会你使用python爬虫爬取数据
2022/04/06 Python