Градиент переполнения текста - переход не плавный, когда зависание - PullRequest
0 голосов
/ 19 марта 2019

У меня есть выпадающий список, где текст переполнения градиентный. К обёртке выделения применён переход, но теперь он выглядит немного странно, когда он находится наверху. Как я могу заставить его выглядеть лучше?

фрагмент HTML:

<div class="durationDropdown">
  <select role="listbox" class="durationSelect">
   <option value="0">Less than 1 month</option>
  </select>
</div>

фрагмент CSS:

.container {
  width: 150px;
}

.durationDropdown {
  padding: 0px;
  flex: 1;
  text-align: left;
  position: relative;
  cursor: pointer;
  height: 5.1875rem;
  transition: 250ms;
  border: 1px solid #eee;
}

.durationDropdown::after {
  content: "";
  display: block;
  width: 40px;
  top: 0%;
  right: 0;
  height: 100%;
  position: absolute;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 63%);
  pointer-events: none;
}

.durationDropdown:hover::after,
.durationDropdown:active::after {
  background: none;
}

.durationDropdown:hover {
  background: black;
}

Вот моя скрипка , где вы можете увидеть, как она выглядит, и остальную часть CSS в скрипке. Любая помощь / предложения будут великолепны!

1 Ответ

0 голосов
/ 19 марта 2019

Боюсь, вы не можете добавить переход к градиенту, подробности см. Здесь Используйте CSS3-переходы с градиентным фоном .

То, что вы действительно видите, это плавное изменение свойства 'color', ноне градиентный переход.Если вы хотите скрыть часть предложения с градиентом и иметь плавный переход по нему, вы можете сделать это следующим образом: - Добавить переход к элементу durationDropdown :: after и заменить background: none;по 'непрозрачности: 0;'вот так:

.durationDropdown::after {
  ...
  transition: 250ms opacity ease-in-out;
  ...
}

.durationDropdown:hover::after,
.durationDropdown:active::after {
  /* background: none; */
  opacity: 0;
}  
...