it-swarm.com.ru

Ширина перехода CSS справа налево

Я создал заголовок (Word Welcome), который раскрывается после загрузки страницы (onload="").

Fiddle в случае, если приведенный ниже код не работает.

function animate() {
  document.getElementById("mainText").style.width = "100%";

}
#mainText {
  margin: 0px;
  display: inline-block;
  font-size: 100px;
  width: 0%;
  transition: width 2s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
}
<body onload="animate()">
  <h1 id="mainText">Welcome</h1>
</body>

CSS и Plain JS работают нормально, но я хочу, чтобы слово «Welcome» сначала отображалось с правой стороны, а затем двигалось вперед, то есть от e к W, вместо того, как оно есть в настоящее время, которое открывается слева направо.

Я пробовал text align: right;, но это ничего не меняет.

Я предпочтительно не хочу использовать jQuery, если решение - JS.

Пример того, каким должен быть желаемый вид, на полпути через переход:

5
Oliver Murfett

Да, это возможно с помощью переходов и позиций:

window.onload = function () {
  document.querySelector("h1").classList.add("active");
};
h1 {
  overflow: hidden;
  display: inline-block;
  position: relative;
}
h1 .mask {
  position: absolute;
  transition: all 0.5s linear;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  background-color: #fff;
}
h1.active .mask {
  right: 100%;
}
<h1><span class="mask"></span>Welcome</h1>

Я только что написал статью об этом - CSS Transitions & JavaScript for Animated Entry Effects . Надеюсь, это полезно ... :)

4
Praveen Kumar Purushothaman

Вы можете использовать свойство clip-path , чтобы обрезать части элемента, чтобы они не были видны. Это свойство также можно анимировать, чтобы снова отобразить элемент, используя ключевое слово forwards в анимации, чтобы оно оставалось в своем конечном состоянии «раскрыто».

inset принимает значения в следующем порядке: сверху, снизу, снизу и слева.

#text {
  margin: 0;
  font-size: 100px;
  animation: reveal 2s forwards;
}

@keyframes reveal {
  from {
    clip-path: inset(0 0 0 100%);
  }
  to {
    clip-path: inset(0 0 0 0);
  }
}
<h1 id="text">Welcome</h1>

4
Jon Koops

Одним из вариантов является transform: translate с псевдоэлементом, и дополнительный элемент не требуется.

function animate() {
  document.getElementById("mainText").classList.add('show');
}
#mainText {
  position: relative;
  margin: 0px;
  display: inline-block;
  font-size: 100px;
  white-space: nowrap;
  text-overflow: clip;
  overflow: hidden;
}
#mainText::after {
  content: '';
  position: absolute;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: white;
  transition: transform 2s;
}
#mainText.show::after {
  transform: translateX(-100%);
}
<body onload="animate()">

    <h1 id="mainText">Welcome</h1>
    
</body>


Другой вариант, еще лучшее решение, использующее псевдо с direction и left/width

Это работает точно так же, как clip-path, полностью прозрачно на фоне, в отличие от маски с текстами, и с гораздо лучшей поддержкой браузера.

function animate() {
  document.getElementById("mainText").classList.add('show');
}
body {
  background: black;
}
#mainText {
  position: relative;
  margin: 0px;
  display: inline-block;
  font-size: 100px;
  white-space: nowrap;
  color: rgba(0, 0, 0, 0);
}
#mainText::before {
  content: attr(data-text);
  position: absolute;
  left: 100%;
  top: 0;
  width: 0;
  height: 100%;
  color: white;
  direction: rtl;
  overflow: hidden;
  transition: left 2s, width 2s;
}
#mainText.show::before {
  left: 0;
  width: 100%;
}
<body onload="animate()">

  <h1 id="mainText" data-text="Welcome">Welcome</h1>

</body>

3
LGSon

Что-то вроде этого

function animate() {
  document.getElementById("overlay").style.width = "0%";

}
#mainText {
  margin: 0px;
  display: inline-block;
  font-size: 100px;
  width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
}
#overlay{
  width: 100%;
  position:absolute;
  top:0;
  left:0;
  background:#fff;
  transition: width 2s;
  height:100%;
}
<body onload="animate()">
  <h1 id="mainText">Welcome</h1>
  <div id="overlay"></div>
</body>

2
Abhishek Pandey

Я использую Transform: translateX для достижения желаемого эффекта. 

Это скользит текст вбок или по горизонтали по оси X. 

.message {
  color: darkred;
  font-size: 30px;
  display: inline-block;
  font-weight: 100;
  font-family: sans-serif;
}

.sliding-text-1,
.sliding-text-2,
.sliding-text-3 {
  animation-name: slide;
  animation-duration: 1s;
  animation-timing-function: ease-out;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
  opacity: 0;
}

.sliding-text-2 {
  animation-delay: 2s;
  color: darkblue;
}

.sliding-text-3 {
  animation-delay: 4s;
  color: darkgreen;
}

@keyframes slide {
  from {
    transform: translateX(200px);
  }
  to {
    transform: translateX(0px);
    opacity: 1;
  }
}
<h1 class="message sliding-text-1">Hello!</h1>
<h1 class="message sliding-text-2">Thanks for visiting!</h1>
<h1 class="message sliding-text-3">Have a Nice day!</h1>

0
I haz kode

Для этого потребуется псевдоэлемент с фоном поверх заголовка, служащий маской. Вместо изменения встроенных стилей я просто добавлю класс is-active. Так что все, что связано со стилем, можно стилизовать с помощью CSS.

function animate() {
  document.getElementById("mainText").className = "is-active";
}
#mainText {
  margin: 0px;
  display: inline-block;
  position: relative;
  font-size: 100px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
}

#mainText:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 100%;
  background: #FFF;
  transition: width 2s;
}

#mainText.is-active:before {
  width: 0%;
}
<body onload="animate()">
  <h1 id="mainText">Welcome</h1>
</body>

0
AlexG