Неизвестная ошибка / ошибка в JS (или CSS) Fluent Reveal Effect в моем коде - PullRequest
0 голосов
/ 11 апреля 2020

Итак, я делаю CSS и JavaScript файлы, которые помогают создавать Windows 10 Fluent Design-подобные сайты. И это включает в себя эффект выявления беглости. Я сделал часть, где легкий радиальный градиент распространяется вокруг курсора, но у меня есть некоторые ошибки, которые не позволяют мне делать этот эффект волны / пульсации после нажатия на элемент открытия.
При нажатии на элемент, есть два волны / пульсации отображаются вместо одной (одна у курсора, другая в каком-то другом месте за пределами элемента, и я знаю, что это не случайная позиция, потому что волна всегда начинается в той же точке при нажатии в том же месте).
Думаю, мой код поможет вам лучше понять:

const clickReveal = function(element, e) {
  let X = e.pageX - element.offsetLeft - 5;
  let Y = e.pageY - element.offsetTop - 5;
  let rippleDiv = document.createElement('div');
  rippleDiv.className = 'ripple';
  rippleDiv.setAttribute('style', 'top: ' + Y + 'px; left: ' + X + 'px;');
  element.appendChild(rippleDiv);
  setTimeout(function() {
    element.removeChild(rippleDiv);
  }, 1000);
};


let revealElementsList = document.getElementsByClassName('reveal');
for (let index=0; index < revealElementsList.length; index++) {
  let revealElement = revealElementsList[index];
  revealElement.addEventListener('click', (event) => {
    clickReveal(revealElement, event);
  }, false);
}
/* PROBABLY NOT THE MAIN PART */
:root {
  --windows-dark-color-light: rgba(100, 100, 100, 1);
  --windows-dark-color-normal: rgba(64, 64, 64, 1);
  --windows-dark-color-dark: rgba(45, 45, 45, 1);
  --button-click: cubic-bezier(0.5, 0, 0, 1);
  --linear: cubic-bezier(0, 0, 1, 1);
  --noise-1: url();
}



@keyframes buttonclick {
  0% {transform: scale(1); background-color: var(--windows-dark-color-light);}
  50% {transform: scale(0.975); background-color: var(--windows-dark-color-normal);}
  100% {transform: scale(1); background-color: var(--windows-dark-color-light);}
}

@keyframes rippleeffect {
  0% {transform: scale(0); opacity: 1;}
  100% {transform: scale(30); opacity: 0;}
}



.button {
  font-family: 'Segoe UI', 'SegoeUI', 'Helvetica Neue', Helvetica, sans-serif;
  font-weight: 300;
  color: rgba(255, 255, 255, 1);
  background-color: var(--windows-dark-color-normal);
  border-radius: 5px;
  border: 2px solid transparent;
  outline: none;
  padding: 5px 12.5px;
}

.button:hover {
  background-color: var(--windows-dark-color-dark);
}

.button:focus {
  animation: buttonclick 1s var(--button-click) 1;
  -webkit-animation: buttonclick 1s var(--button-click) 1;
  -moz-animation: buttonclick 1s var(--button-click) 1;
  -o-animation: buttonclick 1s var(--button-click) 1;
  -ms-animation: buttonclick 1s var(--button-click) 1;
}


/* PROBABLY THE MAIN PART */
.reveal {
  background-image: var(--noise-1), radial-gradient(circle at 0% 0%, rgba(31, 31, 31, 0), rgba(31, 31, 31, 0));
  border: 2px solid transparent;
  border-radius: 0px;
  overflow: hidden;
}

  .reveal .ripple {
    position: absolute;
    background-image: radial-gradient(circle, rgba(255, 255, 255, 0.75) 50px, rgba(255, 255, 255, 0) 50px);
    border-image: radial-gradient(circle, rgba(255, 255, 255, 0.25), rgba(255, 255, 255, 0));
    border-radius: 50%;
    width: 10px;
    height: 10px;
    animation: rippleeffect 1s var(--linear) 1;
    -webkit-animation: rippleeffect 1s var(--linear) 1;
    -moz-animation: rippleeffect 1s var(--linear) 1;
    -o-animation: rippleeffect 1s var(--linear) 1;
    -ms-animation: rippleeffect 1s var(--linear) 1;
    opacity: 0;
  }
<button class="button reveal" style="font-size: 100px;">Click me!</button>

Кроме того,

Непрозрачность волны не уменьшается от 1 до 0 к концу, даже если код четко говорит

@keyframes rippleeffect {
  0% {transform: scale(0); opacity: 1;}
  100% {transform: scale(30); opacity: 0;}
}
...