Web制作 × AI

【CSS】テキストを一文字ずつ上下から相互にフェードインさせる方法

コーディングテクニックの実装内容

今回はWeb制作におけるCSSアニメーションの中でテキストアニメーションに関する内容です。テキストを一文字ずつ上下から相互にフェードインさせる方法を紹介します。
CSSによってテキストを1文字ずつアニメーションさせます。

コーディングテクニックの使いどころ

見出しなどに適用して目立たせると効果的です。特にトップページの一番最初に表示される「ヒーローエリア」のタイトルなどに使用すると良いでしょう。

実装難易度・必要なスキル

コーディングとjQueryの基礎的な知識があれば実務未経験のコーダー、マークアップエンジニア、Webデザイナー、エンジニア、副業の初心者など誰でも実装可能です。

実装所要時間は10分程度

CSS,JavaScriptの記述内容

.wrap {
  width: 768px;
  margin: 0 auto;
}
.text {
  margin: 50px 0 0;
  text-align: center;
  font-size: 80px;
}

.text-move {
  display: inline-block;
  opacity: 0;;
  will-change: transform;
}
.text-move:nth-child(odd) {
  transform: translate3d(30px,-50px,0) rotateY(45deg) skewX(-35deg);
}
.text-move:nth-child(even) {
  transform: translate3d(-30px,50px,0) rotateY(45deg) skewX(-35deg);
}

.text.active .text-move:nth-child(1) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.07s cubic-bezier(.08,.92,.35,1),opacity 1s 1.17s;
}
.text.active .text-move:nth-child(2) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.14s cubic-bezier(.08,.92,.35,1),opacity 1s 1.24s;
}
.text.active .text-move:nth-child(3) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.21s cubic-bezier(.08,.92,.35,1),opacity 1s 1.31s;
}
.text.active .text-move:nth-child(4) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.28s cubic-bezier(.08,.92,.35,1),opacity 1s 1.38s;
}
.text.active .text-move:nth-child(5) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.35s cubic-bezier(.08,.92,.35,1),opacity 1s 1.45s;
}
.text.active .text-move:nth-child(6) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.42s cubic-bezier(.08,.92,.35,1),opacity 1s 1.52s;
}
.text.active .text-move:nth-child(7) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.49s cubic-bezier(.08,.92,.35,1),opacity 1s 1.59s;
}
.text.active .text-move:nth-child(8) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.56s cubic-bezier(.08,.92,.35,1),opacity 1s 1.66s;
}
.text.active .text-move:nth-child(9) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.63s cubic-bezier(.08,.92,.35,1),opacity 1s 1.73s;
}
.text.active .text-move:nth-child(10) {
  transform: translate3d(0,0,0) rotateY(0deg) skewX(0deg);
  transition: transform 1s 1.7s cubic-bezier(.08,.92,.35,1),opacity 1s 1.8s;
}

.text.active .text-move {
  opacity: 1;
  transform: translate(0);
}

@media screen and (max-width:640px){
  .wrap {
    width: 100%;
  }
  .text-move {
    font-size: 8vw;
  }
}

実装のポイント

jQueryを使用してpタグ内のテキストを一文字ずつspanタグで囲んでいます。

PR
[商品価格に関しましては、リンクが作成された時点と現時点で情報が変更されている場合がございます。]

ChatGPT 120%活用術 [ ChatGPTビジネス研究会 ]
価格:1,390円(税込、送料無料) (2023/5/23時点)


この記事を書いた人(著者情報)

片山

カタチップ編集長。昭和生まれの30代でWeb業界歴は10年以上。現在はカタチップを運用しつつ事業会社でWEBメディアサイトのWebディレクター兼マークアップエンジニアを担当。最近はSNSの運用にも業務範囲を拡大中です。

著者画像

スポンサーリンク