【问题标题】:Making a responsive navigation bar with a search button使用搜索按钮制作响应式导航栏
【发布时间】:2014-09-10 14:52:47
【问题描述】:

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

但搜索按钮不会向右移动,折叠时选项卡会拆分并移至下一行。在下载 Wordpress 按钮的地方,我想要登录和注册按钮。折叠品牌名称时,搜索按钮和打开菜单的栏应显示在同一行。

有人能告诉我怎么做吗? 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;
    }
}

【问题讨论】:

  • 有人在回答吗?
  • 你能展示一下它在全视图中的样子吗

标签: jquery html css wordpress twitter-bootstrap


【解决方案1】:

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

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>

【讨论】:

    【解决方案2】:

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

    Js Fidllehttp://jsfiddle.net/8hrnkbaL/1/

    你的第一个问题是 bootstrap 在 jQuery 之前加载,但是 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>
    

    【讨论】:

    • 真的很棒,先生,但我看起来像这样blog.teamtreehouse.com/…
    • 搜索按钮应该在顶部而不是底部
    • 对不起,我正在睡觉(欧罗巴)类似 jsfiddle.net/8hrnkbaL/2 的东西,只需将表单标签移动到第一个位置...
    • 我想要的 90%,但是当全宽时,我希望搜索按钮显示在与品牌名称浮动到右侧的同一行中。并且在折叠时它应该显示一个搜索图标,点击它应该只显示搜索栏。请参阅不同尺寸的blog.teamtreehouse.com/…。你能把它变得相似吗?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-12-18
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多