改进Bootstrap中的响应式侧边栏

原创 2016年08月30日 14:41:11

     侧边栏在响应式设计中起到很大的作用,当屏幕小到手机的屏幕时,能够自适应屏幕大小的侧边栏固然能够为网站添加色彩,那么在Bootstrap的框架中提供了导航条和下拉菜单的组件,详情请自行到官网Bootstrap的文档查看,这里就不作介绍了。

   本文是将其中的导航条和下拉菜单进行结合,然后设计并改进了侧边栏的制作。


html:

<div class="container">
    <nav class="navbar navbar-default mynavbar">
        <div class="container-fluid">
            <!--按钮-->
            <div class="navbar-header">
                <button type="button" class="navbar-toggle collapsed btn-sider" data-toggle="collapse" data-target="#side-menu" aria-expanded="false">
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                </button>
            </div>

            <!-- 导航条内容 -->
            <div class="collapse navbar-collapse" id="side-menu">
                <ul class="nav navbar-nav" id="side-item">
                    <li><a href="#">后端开发</a></li>
                    <li><a href="#">数据库</a></li>
                    <li class="dropdown">
                        <a href="#" class="dropdown-toggle" id="web-item" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">前端开发 <span class="caret"></span></a>
                        <!--下拉菜单按钮-->
                        <ul class="dropdown-menu">
                            <li><a href="#">HTML/CSS</a></li>
                            <li><a href="#">JavaScript</a></li>
                            <li><a href="#">jQuery</a></li>
                            <li><a href="#">Bootstrap</a></li>
                            <li><a href="#">node.js</a></li>
                        </ul>
                    </li>
                    <li><a href="#">移动开发</a></li>
                    <li><a href="#">视觉设计</a></li>
                    <li><a href="#">云计算</a></li>
                </ul>
            </div>
        </div>
    </nav>
</div>

css:

        .mynavbar{
            background-color: #fff;
            border:none;
        }
        .navbar-header,#side-item{
            background-color: #0b3558;
        }

        #side-menu>ul>li>a{
            color:#fff;
            font-size: 18px;
            font-family: "Microsoft Yahei", Helvetica, sans-serif, Lato;
        }
        #side-menu>ul{
            width: 100%;
        }
        #side-menu>ul>li{
            text-align: center;
            width: 16%;
            margin-left: 5px;
        }
        #side-menu .dropdown-menu {
            border: none;
            -webkit-box-shadow: 0 6px 12px rgba(0,0,0,.175);
            box-shadow: 0 6px 12px rgba(0,0,0,.175);
        }
        #side-item .dropdown-menu>li>a:focus, .dropdown-menu>li>a:hover,#side-item>li>a:focus,#side-item >li>a:hover {
            color: #24b0ff;
            text-decoration: none;
            background-color: transparent;
        }
        .btn-sider{
            float: left;
            border:none;
            outline: none;
            margin-left: 10px;
        }
        .mynavbar .btn-sider .icon-bar{
            background-color:#fff;
            width:23px;
            height:3px;
        }
        .mynavbar .btn-sider:focus, .mynavbar .btn-sider:hover {
            background-color: transparent;
        }
        @media (max-width: 768px) {
            .container {
                padding-left: 0px;
            }
            #side-menu{
                border: none;

            }
            #side-item{
                background: rgba(43, 54, 67, 0.97);
            }
            #side-menu>ul {
                margin-top: 0px;
                margin-right: 0px;
                margin-left: -15px;
                margin-bottom: 0px;
                width: 40%;
                height: 999px;
            }
            #side-menu>ul>li {
                text-align: left;
                width:100%;
                margin-left:0px;
            }
            #side-menu>ul>li a{
                font-size:16px;
            }
            #side-item>li>a:focus,#side-item >li>a:hover,#side-item .dropdown-menu>li>a:focus, .dropdown-menu>li>a:hover{
                background-color: #38a99c;
                color:#fff;
            }
            #side-menu .dropdown-menu{
                box-shadow:none;
            }
            #side-menu .dropdown-menu li a{
                padding-top:10px;
                color:#fff;
            }
        }




版权声明:本文为博主原创文章,如需要转载,请标明文章出处,谢谢。

Bootstrap模板Metronic设置默认选中侧边栏

一开始我们拿到的模板页面如下图所示,但是在给出的模板中,每个页面都包含了左侧的侧边栏代码,这在我们开发系统的时候,显然不能这么做,不利于变更,重复性也很大,但是如果是放在一个文件中统一包含进来的话,就...

Bootstrap 折叠(Collapse)插件制作侧边栏导航菜单

data-toggle="collapse" 添加到您想要展开或折叠的组件的链接上。 href 或 data-target 属性添加到父组件,它的值是子组件的 id。 下表列出了折叠(Collap...

bootstrap 响应式 导航栏

  • 2017年07月17日 11:58
  • 66KB
  • 下载

Bootstrap的js插件之侧边栏停靠(affix)

下面是一个比较常见的侧边栏停靠的例子: js插件_侧边栏停靠 --> .affixed-elemen...
  • bboyjoe
  • bboyjoe
  • 2015年08月08日 15:23
  • 4237

bootstrap实现响应式导航栏,折叠隐藏效果

bootstrap实现响应式导航栏 PC机显示正常的长条导航,手机端实现折叠隐藏的按钮效果 向 标签添加 class .navbar、.navbar-default(导航条背景白)nav...

bootstrap 导航栏居中响应式剧中布局

Title ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:改进Bootstrap中的响应式侧边栏
举报原因:
原因补充:

(最多只允许输入30个字)