Подтвердить что ты не робот

Bootstrap 3 - Как увеличить ширину ввода внутри navbar

Сейчас у меня есть панель навигации, которая выглядит так: http://bootply.com/78239

Я хочу максимизировать ширину текстового ввода "поиск" без создания разрывов строк (т.е. что ссылка "Очистить" будет жесткой с помощью ссылки "О программе" ).

У меня есть только базовый опыт работы с CSS и веб-дизайном. Я прочитал кое-что о трюках overflow: hidden, но я не понимаю, как его использовать, когда есть элементы справа от целевого элемента.

Спасибо


EDIT:

Частным решением может быть установка ширины "вручную" для каждого случая, например, в http://bootply.com/78247:

@media (max-width: 767px) {
  #searchbar > .navbar-form {
    width: 100%;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  #searchbar > .navbar-form {
    width: 205px;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  #searchbar > .navbar-form {
    width: 425px;
  }
}

@media (min-width: 1200px) {
  #searchbar > .navbar-form {
    width: 625px;
  }
}

но это решение не будет работать, если тексты меню являются "динамическими" (например, содержат "Hello username" ).

Я полагаю, что это не большая проблема, если вы предполагаете, что существует ограничение на ширину текста текста - это просто раздражает, чтобы вычислить/проверить эти ширины вручную. Мне просто интересно узнать, есть ли аккуратный способ сделать это автоматически.

4b9b3361

Ответ 1

Для Bootstrap версии 3.2 и выше вы также должны установить display:table; для input-group и установить ширину 1% для input-group-addon.

<div style="display:table;" class="input-group">
            <span style="width: 1%;" class="input-group-addon"><span class="glyphicon glyphicon-search"></span></span>
            <input type="text" autofocus="autofocus" autocomplete="off" placeholder="Search Here" name="search" style="" class="form-control">
          </div>

Демо-версия Bootstrap версии 3.2+: http://www.bootply.com/t7O3HSGlbc

-

Если вы разрешите изменять положение своих элементов навигационной панели? Я не понимаю ", не создавая перерывы (т.е. Что ссылка" Очистить "будет жесткой с ссылкой" О программе ")". Попробуйте следующее: http://bootply.com/78374.

Что я сделал:

  • Отбросьте float слева от формы (отбросив класс слева от навигатора)
  • Дайте другим элементам навигатора правильный поплавок (класс, соответствующий navbar-right)
  • Установить отображение группы форм в строку (style="display:inline")
  • Измените положение элементов (сначала поместив их справа)

Похожие вопросы:

HTML

<div class="navbar navbar-inverse navbar-fixed-top">
  <div class="container">
    <div class="navbar-header">
      <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
      </button>
      <a class="navbar-brand" href="#">My Project</a>
    </div>
    <div class="navbar-collapse collapse" id="searchbar">

      <ul class="nav navbar-nav navbar-right">
        <li><a href="about.html">About</a></li>
        <li id="userPage">
          <a href="#@userpage"><i class="icon-user"></i> My Page</a>
        </li>
        <li><a href="#logout" data-prevent="">Logout</a></li>
      </ul>
      <ul class="nav navbar-nav navbar-right">
        <li><a href="#" title="Start a new search">Clear</a></li>
      </ul>



     <form class="navbar-form">
        <div class="form-group" style="display:inline;">
          <div class="input-group">
            <span class="input-group-addon"><span class="glyphicon glyphicon-search"></span></span>
            <input class="form-control" name="search" placeholder="Search Here" autocomplete="off" autofocus="autofocus" type="text">
          </div>
        </div>
      </form>

    </div><!--/.nav-collapse -->
  </div>
</div>

Ответ 2

Для меня здесь работали две вещи. Добавление запросов медиаресурсов Orens, а также добавление display: inline к этой группе форм поиска:

<li id="searchbar">
          <form id="search_form" class="navbar-form navbar-left navbar-input-group " role="search">
            <div class="input-group">
              <div class="input-group-btn">
                <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-expanded="false">All <span class="caret"></span>
                </button>
              </div>
              <div class="form-group">
                <input name="search_input" type="text" class="form-control typeahead" placeholder="Search for items or shops" autofocus="autofocus">
              </div>
              <span class="input-group-btn">
          <button type="submit" class="btn btn-default"><i class="fa fa-search"></i>
          </button>
          </span>
            </div>
          </form>
        </li>

С помощью css:

#search_form > .input-group > .form-group {
  display: inline;
}