質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

0回答

198閲覧

スクロールするたびにスクロールイベントが適応されてしまう

amagiri

総合スコア68

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

1クリップ

投稿2022/05/18 14:05

前提・実現したいこと

画面が指定の位置に来た時、<span>で囲んだ文字が下から上がってくるアニメーションを実装したいんですが、スクロールするたびにアニメーションが適応されてしまうのはなぜでしょうか。

該当のソースコード

HTML

1 <main> 2 <div class="text-animation">テキストテキストテキスト</div> 3 <div class="text-animation">TextText TextText</div> 4 </main>

CSS

1/* ====== header ====== */ 2header { 3 height: 100vh; 4} 5 6/* ====== main ====== */ 7main { 8 height: 100vh; 9 background: black; 10 display: flex; 11 justify-content: center; 12 align-items: center; 13 flex-flow: column; 14} 15 16.text-animation { 17 color: white; 18 font-size: 50px; 19} 20 21.text-animation span { 22 display: inline-block; 23} 24 25@keyframes activeText { 26 from { 27 opacity: 0; 28 transform: translateY(100%); 29 } 30 to { 31 opacity: 1; 32 transform: none; 33 } 34} 35 36.text-animaiton > span { 37 overflow: hidden; 38} 39 40.text-animation > span > span { 41 animation: activeText 1s backwards; 42}
'use strict'; function slideText(){ const textAnimation = document.querySelectorAll('.text-animation'); for(let i = 0; i < textAnimation.length; i++) { const textDivition = textAnimation[i], texts = textDivition.textContent, textArray = []; textDivition.textContent = ""; for (let j = 0; j < texts.split("").length; j++) { if(texts.split("")[j] === " ") { textArray.push(" ") } else { textArray.push('<span><span style="animation-delay: ' + (j * .1) + 's;">' + texts.split("")[j] + '</span></span>') } } for(let k = 0; k < textArray.length; k++) { textDivition.innerHTML += textArray[k] } } } const mainElement = document.getElementsByTagName('main'); document.addEventListener('scroll', function(){ for(let i = 0; i < mainElement.length; i++) { const mainDistance = mainElement[i].getBoundingClientRect().top + mainElement[i].clientHeight *.5 if(window.innerHeight > mainDistance) { slideText(); } } });

補足情報(FW/ツールのバージョンなど)

dynabook V72/JLE
型番:PV82JLECNRDQE

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

amagiri

2022/05/18 14:35

処理を一度で終わらせる方法を検索して{once: true}を入れてみたんですが「Uncaught ReferenceError: ture is not defined」と出てしまいました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問