実現したいこと
スクロールイベントで、指定の位置までスクロールしたら、
classを追加して、アニメーションさせたいです。
指定の位置でなければ、classを削除させて、また指定の位置までスクロールしたら、
アニメーションさせたいのですが、
classが追加されるところまではできましたが、
classの削除ができません。
前提
jqueryではなく、javascriptを使用して行いたいです。
classに「panda」を持っている要素全てにアニメーションさせたいです。
指定の位置までスクロールしてきたら、class「fadeUp」を追加、
指定の位置でなければ、class「fadeUp」を削除したいです。
コードが長すぎるので、一部抜粋ですが、
classに「panda」を持っている要素は、他にも4つあります。
発生している問題・エラーメッセージ
エラーメッセージは出ていません。
該当のソースコード
HTML
1<section id="vision"><!---Our Vision---> 2 <h1 class="name panda">Our Vision</h1> 3 <h1 class="upanime">世の中の課題をITで解決して、<br>関わった<span>世界中の人たちを幸せにする</span></h1> 4 <div id="world"><!---三か条--> 5 <div class="third upanime"> 6 <h1>ITを通じて<br>人々の可能性を広げる</h1> 7 <h2>イノベーションを起こし新たな価値を創造する</h2> 8 </div> 9 <div class="third upanime"> 10 <h1>世界を代表する<br>自社サービスを作る</h1> 11 <h2>世の中にインパクトを与える</h2> 12 </div> 13 <div class="third upanime"> 14 <h1>世界から選ばれる<br>企業へ</h1> 15 <h2>常に最高のパフォーマンスを発揮します</h2> 16 </div> 17 </div><!---三か条--> 18 </section><!---Our Vision--->
css
1.fadeUp { 2 animation-name: fadeUpAnime; 3 animation-duration: 0.7s; 4 animation-fill-mode: forwards; 5 opacity: 0; 6} 7 8@keyframes fadeUpAnime { 9 from { 10 opacity: 0; 11 transform: translateY(-50px); 12 } 13 14 to { 15 opacity: 1; 16 transform: translateY(0); 17 } 18}
javascript
1 const element = document.querySelectorAll(".panda"); 2 const screenHeight = window.scrollY; 3 let height = window.innerHeight; 4 const apperPoint = screenHeight*0.3; 5 6 window.addEventListener("scroll",() => { 7 for(let i = 0; i < element.length; i++){ 8 const elemPos = element[i]; 9 const elementHeightTotop = elemPos.getBoundingClientRect().top; 10 if(screenHeight >= elementHeightTotop - height){ 11 elemPos.classList.add("fadeUp"); 12 } else { 13 elemPos.classList.remove("fadeUp"); 14 } 15 } 16 })
試したこと
elseの部分を下記に書き換えてもダメでした。
解決方法が見出せないため、質問させていただきました。
javascript
1else if (elemPos.classList.contains('gadeUp') == true) { 2elemPos.classList.remove("fadeUp");

回答3件
あなたの回答
tips
プレビュー