使用搜索按钮创建响应式导航栏

时间:2014-09-10 14:52:47

标签: jquery html css wordpress twitter-bootstrap

我正在尝试使用bootstrap制作响应式导航栏。我想像http://wordpress.org/support/topic/want-to-move-search-option-from-header-to-navigation-bar那样构建。

但是搜索按钮不会向右移动,当折叠时,标签会分开并移动到下面的一行。在下载Wordpress按钮的地方我想要LogIn和SignUp按钮。折叠品牌名称时,搜索按钮和打开菜单的栏应显示在同一行中。

有人可以告诉你怎么做吗? See my code

            

            <!-- Brand and toggle get grouped for better mobile display -->
            <div class="navbar-header">
                <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#navbar-collapse-1">
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                </button>

                <a class="navbar-brand" href="#">Brand Name</a>

                <form class="navbar-form navbar-right" style="float: right;" role="search">
                    <input type="text" class="form-control" placeholder="Search">
                </form>
            </div>

            <div style="clear:both"></div>

            <!-- Collect the nav links, forms, and other content for toggling -->
            <div class="collapse navbar-collapse" id="navbar-collapse-1">
                <ul class="nav navbar-nav navbar-left">
                    <li class="active"><a href="#">Home</a></li>
                    <li><a href="#">Highlights</a></li>
                    <li><a href="#">Test Yourself</a></li>
                    <li><a href="#">Interesting Questions</a></li>
                    <li><a href="#">Ask Queries</a></li>
                </ul>

                <ul class="nav navbar-nav navbar-right">
                    <li><a href="#">SignUp</a></li>
                    <li><a href="#">LogIn</a></li>
                </ul>
            </div>
        </div>
    </nav>

.navbar {
    min-height: 120px;
}

.navbar .container {
    padding-top: 20px;
    padding-bottom: 20px;
}

.navbar-nav>li>a {
    text-transform: uppercase;
    font-family: "jokerman";
    font-size: 16px;
}

@media (min-width: 768px)   {
    .navbar-nav {
        margin: 0 auto;
        display: table;
        table-layout: fixed;
        float:  none;
    }
}

2 个答案:

答案 0 :(得分:2)

我为你绘制了这个例子,这就是我的意思,保持简单,随意使用它并使用css3媒体查询编辑移动设备。 你还可以使用:

position:absolue;right:7px;

用于移动设备右侧的菜单切换按钮 你也可以使用:

position:absolue;left:7px;

左边的ul,祝你好运 - Millzie:)

<html>
<head>
<title>My menu V.1</title>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script type="text/javascript">
 jQuery(document).ready(function($){
  $('.menu-right').click(function(){
   var animationTime = 800;
   if($('.menu').css('height') == '60px'){
    $('.menu').animate({'height':'80px'}, animationTime, 'linear');
   }else if($('.menu').css('height') == '80px'){
    $('.menu').animate({'height':'60px'}, animationTime, 'linear');
   }
  });
 });
</script>
<style type="text/css">
 *{margin:0;padding:0;border:0;border-radius:0;font-family:sans;}
 div.menu{width:100%;height:60px;background-color:#660033;overflow:hidden;}
 ul.menu-ul{float:left;padding-left:7px;}
 li.menu-li{display:inline;list-style:none;font-size:15px;line-height:60px;margin-right:7px;}
 li.menu-li:hover{border-bottom:2px solid #FFFFFF;color:#FFFFFF;}
 div.menu-right{float:right;line-height:60px;font-size:15px;margin-right:7px;}
 div.menu-right:hover{color:#FFFFFF;}
 /*search form*/
 input.search{width:900px;height:20px;margin-top:-3px;margin-left:7px;background-color:#FFFFFF;}
 input.search-button{width:70px;height:20px;margin-top:-3px;margin-left:4px;background-color:#FFFFFF;}
 </style>
</head>
<body>
 <div class="menu">
  <ul class="menu-ul">
   <li class="menu-li">Menu item one</li>
   <li class="menu-li">Menu item two</li>
   <li class="menu-li">Menu item three</li>
   <li class="menu-li">Menu item four</li>
   <li class="menu-li">Menu item five</li>
  </ul>
  <div class="menu-right">Search</div>
  <form>
   <input type="text" class="search" value="search for something" />
   <input type="submit" class="search-button" value="search" />
  </form>
 </div>
</body>
</html>

答案 1 :(得分:1)

我真的不明白你的search-input是否应该在xs视图中可见但是这里有效:

Js Fidlle http://jsfiddle.net/8hrnkbaL/1/

你的小提琴中的第一个问题是在jQuery之前加载了bootstrap,但 jQuery必须首先加载 ......

HTML:

<nav class="navbar navbar-inverse navbar-fixed-top" role="navigation">

        <div class="container">

            <!-- Brand and toggle get grouped for better mobile display -->
            <div class="navbar-header">
                <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#navbar-collapse-1">
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                </button>

                <a class="navbar-brand" href="#">Brand Name</a>
            </div>

            </div>

            <div style="clear:both"></div>

            <!-- Collect the nav links, forms, and other content for toggling -->
            <div class="collapse navbar-collapse" id="navbar-collapse-1">
                <ul class="nav navbar-nav navbar-left">
                    <li class="active"><a href="#">Home</a></li>
                    <li><a href="#">Highlights</a></li>
                    <li><a href="#">Test Yourself</a></li>
                    <li><a href="#">Interesting Questions</a></li>
                    <li><a href="#">Ask Queries</a></li>
                </ul>

                <ul class="nav navbar-nav navbar-right">
                    <li><a href="#">SignUp</a></li>
                    <li><a href="#">LogIn</a></li>
                </ul>
                <form class="navbar-form navbar-right" role="search">
                          <div class="form-group">
      <input type="text" class="form-control" placeholder="Search"/>
    </div>

                </form>
            </div>
        </div>
    </nav>