CSS на фокусе изменить стиль другого div - PullRequest
0 голосов
/ 10 мая 2018

Я хочу, чтобы svg изменил цвет заливки, когда пользователь сфокусировался на вводе. Но я не понимаю, как написать CSS, чтобы это произошло. Добавлены HTML и CSS для вас, чтобы проверить! Я использую Scss для CSS.

<div class="search">
    <svg width="20px" height="20px" viewBox="0 0 88 88" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
        <g id="Symbols" stroke="none" stroke-width="1" fill-rule="evenodd">
            <g id="Icon-Search" fill="#b3b3b3" fill-rule="nonzero">
                <path d="M86.829,81.172 L64.128,58.471 C69.055,52.312 72,44.5 72,36 C72,16.118 55.883,0 36,0 C16.118,0 0,16.118 0,36 C0,55.882 16.118,72 36,72 C44.5,72 52.312,69.054 58.471,64.127 L81.172,86.828 C81.953,87.609 82.977,88 84,88 C85.024,88 86.048,87.609 86.829,86.828 C88.391,85.267 88.391,82.733 86.829,81.172 Z M36,64 C20.536,64 8,51.464 8,36 C8,20.536 20.536,8 36,8 C51.465,8 64,20.536 64,36 C64,51.464 51.465,64 36,64 Z" id="Shape"></path>
            </g>
         </g>
      </svg>

      <input class="input inputSearchField" type="text" placeholder="Search...">
  </div> 



.input{
    width: 250px;
    height: 35px;
    padding-left: 16px;
    font-weight: 700;
    background-color: $white-color;
    border-radius: 4px;
    border: 1px solid $lighter-gray;
    font-size: 16px;
    outline:none;
    transition: all 0.30s ease-in-out;
    &::placeholder {
        color: $light-gray;
    }
    &:focus {
        box-shadow: 0 0 5px #64e469;
        border: 1px solid #64e469;
    }
}
.search { 
    position: relative;
    margin: 0 auto;
    text-align: center;
    width: 270px;
    margin-bottom: 30px;
  }
  .search svg { 
    position: absolute;
    top: 7px;
    right: 22px;
    fill: $lighter-gray;
  }

Ответы [ 2 ]

0 голосов
/ 10 мая 2018

Проверьте это CodePen Demo . Вам нужно переместить ваш ввод до вашего SVG, в противном случае вам придется использовать некоторый JavaScript для этого, потому что CSS не имеет какого-либо селектора «оглядки за спиной». Даже General Sibling Combinator выглядит только впереди текущей цели селектора.

Если вы сначала переместите вход, вы можете просто сделать:

.input:focus + svg #Icon-Search {
  fill: #64e469;
}

Если вы действительно хотите сохранить текущую структуру, JavaScript будет выглядеть примерно так на этом Demo

let search  = document.getElementsByClassName('inputSearchField');
let svgFill = document.getElementById('Icon-Search');

search[0].onfocus = function(){ svgFill.style.fill = '#64e469'; }
search[0].onblur  = function(){ svgFill.style.fill = '#b3b3b3'; }

Вы можете видеть, что это немного более утомительно!

0 голосов
/ 10 мая 2018

Мне интересно, что у вас есть HTML, как это:

<div class="search">
  <input class="input" />
  <svg />
</div>

Ваш CSS может быть примерно таким:

.input:focus + svg { ... }

Если svg предшествует input, тогда вы можете использовать ~ вместо +

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...