ライブラリを使わず、JSで画像をフェードインさせてみる

ライブラリを使わず、JSで画像をフェードインさせてみる:

2パターン書いてみました。

まず1つ目


jsの再起を使ってフェードインさせる


HTML

<!-- 必要最低限 --> 
<body> 
<img id="image" src="https://placehold.jp/150x150.png" alt="画像" style="opacity: 0;"> 
</body> 


JavaScript

function fadeIn(node) { 
      var start = performance.now(); 
      requestAnimationFrame(function tick(timestamp) { 
          var easing = (timestamp - start) / 300; 
          node.style.opacity = Math.min(easing, 1); 
          if (easing < 1) { 
              // 再起 
              requestAnimationFrame(tick); 
          } else { 
              node.style.opacity = ''; 
          } 
    }); 
} 
 
window.onload = function() 
{ 
    fadeIn(document.getElementById("image")); 
} 
実は上記のfadeIn関数は下の記事から関係のない部分を省かせていただき、使わせていただきました。
「脱jQuery」 生JSで.fadeIn()のように要素をフェードインで表示する

ありがてぇ!


CSSでアニメーションさせる

上記のJSでOpacityを弄るのは、正直パフォーマンスが良くない・・・

というわけで、Styleの値の書き換えだけJSにまかせて、アニメーションはCSSにさせる。

HTMLは共通です


CSS

img { 
    transition: all 0.5s; 
    opacity: 0; 
} 


JavaScript

window.onload = function() 
{ 
    var image = document.getElementById("image"); 
    image.style.opacity = 1; 
} 
なんだ、これだけでFadeInできるのか。

これなら簡単にFadeOutも実装できるし、CSS3はやっぱり凄いなぁ。

コメント

このブログの人気の投稿

投稿時間:2021-06-17 22:08:45 RSSフィード2021-06-17 22:00 分まとめ(2089件)

投稿時間:2021-06-20 02:06:12 RSSフィード2021-06-20 02:00 分まとめ(3871件)

投稿時間:2021-06-17 05:05:34 RSSフィード2021-06-17 05:00 分まとめ(1274件)