Я пытался создать выпадающий список начальной загрузки с некоторыми дополнительными кнопками внутри. У меня основные функции отсортированы, но эстетика не совсем верна.

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

В настоящее время я рву свои волосы, пытаясь заставить их работать, но мне не везет, поэтому, если кто-нибудь сможет предложить какую-либо помощь, это будет очень признательно.

Обновление:

Спасибо @Matus Jurika за предложение использовать calc для настройки размера элемента привязки.

Обновленная рабочая скрипка: скрипка

-2
Weagertron 20 Авг 2018 в 11:20

3 ответа

Лучший ответ

Я предлагаю использовать calc для ширины:

.anchorDiv {
    display: inline-block;
    width: calc(100% - 74px);
}

Рабочая скрипка: https://jsfiddle.net/q3fra0bm/36/

2
Matus Jurika 20 Авг 2018 в 09:59

Это должно помочь.

.comboItemContainer {
    width: 100%;
    position: relative;
}

.anchorDiv {
    display: inline-block;
    width: 100%;
    padding: 0 80px 0 0;
}

.comboButtons {
    width: 74px;
    display: block;
    position: absolute;
    top: 0px;
    right: 0px;
}

Я сделал контейнер относительно так, чтобы я мог свободно использовать абсолютное позиционирование на его дочерних элементах с (0,0) происхождением относительно контейнера. Затем я сделал кнопки абсолютными, сделал его верхним 0 и правым 0. Добавил 100% ширину на якорь и 80px padding-right.

Это может выглядеть неприлично, но я не очень хорош во Flex и абсолютно нулевой в Grid.

Это почти наверняка кросс-браузер, хотя

0
Abana Clara 20 Авг 2018 в 09:11

Это здесь фрагмент вашего решения. Я просто использую класс начальной загрузки row.

.comboRow {
    margin-bottom: 3px;
}

.comboItem {
    display: block !important;
    /*width: 67%;*/
}

.comboButtons {
    float:right;
    margin-top: 3px;
    width: 74px;
    display: block;
}

.comboItemContainer {
    width: 100%;
    display: inline-block;
}

.anchorDiv {
    display: inline-block;
}

.close {
    /*float: right;*/
    /*margin-right: 10px;*/
}

.close .edit {
    margin-right: 5px;
}

#presetDropdownButton {
    position:absolute;
}

.glyphicon {
    font-size: 15px;
}

#presetDropdown {
    width: max-content;
}

#newPresetEntry {
    width: 50%;
    height: 24px;
    margin-left: 18px;
    padding-left: 6px;
    padding-right: 6px;
}

.dropdown-menu > li > div > div > a {
    padding: 3px 20px;
    clear: both;
    font-weight: 400;
    line-height: 1.42857143;
    color: #333;
    white-space: nowrap;
    display: block;
}

.dropdown-menu > li > div > div > a:focus {
    color: #262626;
    text-decoration: none;
    background-color: #f5f5f5;
}

.dropdown-menu > li > div > div > a:hover {
    color: #262626;
    text-decoration: none;
    background-color: #f5f5f5;
}

.pl-0 {
  padding-left: 0 !important;
}
.pr-0 {
  padding-right: 0 !important;
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
<div class="dropdown" id="presetDropdownButton">
  <button class="btn btn-primary dropdown-toggle" type="button" data-toggle="dropdown" aria-expanded="false">
    Presets
  <span class="caret"></span>
  </button>
  <ul class="dropdown-menu" id="presetDropdown">
    <li class="comboRow">
      <div class="row">
        <div class="col-md-9 col-xs-9 pr-0">
          <a class="comboItem" href="#" value="1">Preset 1</a>
        </div>
        <div class="col-md-3 col-xs-3 pl-0">
          <button type="button" class="close deletePreset" aria-label="Delete" style="margin-right: 10px;">
            <span aria-hidden="true">&times;</span>
          </button>
          <button type="button" class="close edit editPreset" aria-label="Edit" style="margin-right: 3px;">
            <span aria-hidden="true">&#9998;</span>
          </button>
          <button type="button" class="close edit savePreset" aria-label="Save" style="margin-right: 3px;">
            <span style="font-size: 18px;" aria-hidden="true">&#128190;</span>
          </button>
        </div>
      </div>
    </li>
    <li class="comboRow">
      <div class="row">
        <div class="col-md-9 col-xs-9 pr-0">
          <a class="comboItem" href="#" value="1">Preset 2 with longer name</a>
        </div>
        <div class="col-md-3 col-xs-3 pl-0">
          <button type="button" class="close deletePreset" aria-label="Delete" style="margin-right: 10px;">
            <span aria-hidden="true">&times;</span>
          </button>
          <button type="button" class="close edit editPreset" aria-label="Edit" style="margin-right: 3px;">
            <span aria-hidden="true">&#9998;</span>
          </button>
          <button type="button" class="close edit savePreset" aria-label="Save" style="margin-right: 3px;">
            <span style="font-size: 18px;" aria-hidden="true">&#128190;</span>
          </button>
        </div>
      </div>
    </li>
    <li class="comboRow">
      <div class="row">
        <div class="col-md-9 col-xs-9 pr-0">
          <a class="comboItem" href="#" value="1">Preset 3 with even longer name</a>
        </div>
        <div class="col-md-3 col-xs-3 pl-0">
          <button type="button" class="close deletePreset" aria-label="Delete" style="margin-right: 10px;">
            <span aria-hidden="true">&times;</span>
          </button>
          <button type="button" class="close edit editPreset" aria-label="Edit" style="margin-right: 3px;">
            <span aria-hidden="true">&#9998;</span>
          </button>
          <button type="button" class="close edit savePreset" aria-label="Save" style="margin-right: 3px;">
            <span style="font-size: 18px;" aria-hidden="true">&#128190;</span>
          </button>
        </div>
      </div>
    </li>
  </ul>
</div>
0
Hamid R. 20 Авг 2018 в 09:05
51926660