资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

Bootstrap中导航组件有什么用-创新互联

这篇文章给大家分享的是有关Bootstrap中导航组件有什么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

成都创新互联公司专注于桐梓企业网站建设,响应式网站建设,商城网站开发。桐梓网站建设公司,为桐梓等地区提供建站服务。全流程按需定制设计,专业设计,全程项目跟踪,成都创新互联公司专业和态度为您提供的服务

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

LESS:  navs.less

SASS:  _navs.scss

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

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


        
  • 导航标题1
  •         
  • 导航标题2
  •         
  • 导航标题3
  •         
  • 导航标题4
  •         
  • 导航标题5
  •     

    原理:

    将菜单项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即可

    
            导航标题1
            
  • 导航标题2
  •         
  • 导航标题3
  •         
  • 导航标题4
  •         
  • 导航标题5
  • .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;
    }
    
            
  • 导航标题0
  •         导航标题1         
  • 导航标题2
  •         
  • 导航标题3
  •         
  • 导航标题4
  •         导航标题5

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

  • 
            导航标题0
            导航标题1
            
  • 导航标题2
  •                  
  • 导航标题3
  •         
  • 导航标题4
  •         导航标题5
    .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列表

    
            
  • 导航菜单1
  •         
  • 导航菜单2
  •         
  • 导航菜单3
  •         
  • 导航菜单4
  •                                       导航菜单5                                                            
  • 下拉菜单1
  •                 
  • 下拉菜单2
  •                 
  • 下拉菜单3
  •                 
  • 下拉菜单4
  •                               
  • 导航菜单6
  •     

    面包屑式导航

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

    LESS: breadcrumbs.less

    SASS:_breadcrumbs.scss

    
            
  • 首页
  •         
  • 我的书
  •         图解css     
    .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中导航组件有什么用-创新互联
    链接URL:http://cdkjz.cn/article/dhssgj.html
    多年建站经验

    多一份参考,总有益处

    联系快上网,免费获得专属《策划方案》及报价

    咨询相关问题或预约面谈,可以通过以下方式与我们联系

    业务热线:400-028-6601 / 大客户专线   成都:13518219792   座机:028-86922220