JavaScript

setTimeout は requestAnimationFrame に変えるべき?

requestAnimationFrame をはじめて見たので調べていたら、setTimeout や setInterval は requestAnimationFrame にするべき、のような記事タイトルが多かった。どういうことなのだろうと簡単な調査を行ったのでレビュー。

最初に結論

  • すべての setTimeout や setInterval を requestAnimationFrame に置き換えられるわけではない。requestAnimationFrame は、あくまで「反復処理」しかも「1秒間に30回もしくは60回」の反復処理をする際の話しであることが大前提。たとえば、5秒後に何かしらの処理を実行したい場合や繰り返す処理間隔を任意に指定したい場合は、これまで同様、setTimeout や setInterval を使う
  • setTimeout より requestAnimationFrame のほうが処理間隔が数値的に正確
  • ググると、プレフィックスに判別記述が紹介されていることが多いが、もはや不要

というわけで、この結論に至った経緯を紹介します。

体感レベルでの違いが分からない

簡易的な処理を書いて、10秒実行した結果、数字での違いははっきりあったものの、requestAnimationFrame のスゴさを体感できるほどの違いはなかった。そのため、あえて過去のソースを書き換えるほどではないと判断。

もしかすると電光掲示板のようなデザインであれば、なめらかさに違いが出るかもしれない(未検証)。

そもそも requestAnimationFrame とは?

そもそも、requestAnimationFrame は何か。
ネット上の情報を見ると、一秒間におよそ60回、引数に渡した関数を反復処理する、とある(実際は30回の場合あり、後述)。つまり、1000/60ミリ秒ごとに処理を繰り返すということだ。実際には、一秒間の処理回数は60回と決まっているわけではなく、ブラウザに依存するとのこと。

つまり、requestAnimationFrame の場合、インターバル時間を指定できない。setTimeout や setInterval ではインターバル時間を任意に指定できる。

ソースで書くと似ていることが記法は似ていることがよくわかる。

const sample = () => {
  setTimeout(sample, 1000/60);
}
const sample = () => {
  window.requestAnimationFrame(sample);
}

実際に試した結果

同じネット回線で、10秒間計測して、その間に何回処理をするのか計測してみた。
テストしたコードはこちら
https://sample.simplesimplesdesign.com/requestAnimationFrame/

1秒間に60回処理を実行する想定だから、10秒間では「600」が期待値だ。

requestAnimationFrame setTimeout
macOS12/Chrome92 298 556
iOS14/Safari14 602 579

驚きなのは、macOS12/Chrome92 で、requestAnimationFrameの値が298と期待値の半分であること。1分間に30回の処理という計算になる。

そこで、setTimeout(sample, 1000/30); として測定したところ、287 が返ってきた。requestAnimationFrame の1秒間に30回処理としたら、 requestAnimationFrame は setTimeout より処理回数が理論値に近い(=より正確)ことが分かる。

cancelAnimationFrame

ちなみに、実装レベルでは setTimeout を利用するときには、clearTimeout を併用するが、requestAnimationFrame を利用する場合にも、その処理を途中でキャンセルするメソッドが用意されている。それが、cancelAnimationFrame だ。
使い方はclearTimeoutと同様。

補足: requestAnimationFrameのブラウザ対応状況

ググった情報は、requestAnimationFrameをプリフィックス付きで判別する古い記事が多い。
だがしかし、現状では、よっぽど古いブラウザのケアが必要なければプリフィックス判別はもういらない。

Can I Use...

あらためて結論

  • すべての setTimeout や setInterval を requestAnimationFrame に置き換えられるわけではない。requestAnimationFrame は、あくまで「反復処理」しかも「1秒間に30回もしくは60回」の反復処理をする際の話しであることが大前提。たとえば、5秒後に何かしらの処理を実行したい場合や繰り返す処理間隔を任意に指定したい場合は、これまで同様、setTimeout や setInterval を使う
  • setTimeout より requestAnimationFrame のほうが処理間隔が数値的に正確
  • ググると、プレフィックスに判別記述が紹介されていることが多いが、もはや不要

最近の記事

DaVinci Resolve 17 プロジェクト設定と環境設定

プロジェクト設定と環境設定について詳しく解説されている情報がなかなか見つからないので、要所要所で知り得た情報を更新していきます。 プロジェクト設定 ・・・

DaVinci Resolve

項目”Clipy”は開いているため、ゴミ箱に入れることができません。←アンインストールしようとしたときの話し

Clipyが超絶便利そうだったので、macOS Big Sur にインストール&再起動して使ってみた。ところが、command + c を複数の箇所で行い、c・・・

徒然なままに

setTimeout は requestAnimationFrame に変えるべき?

requestAnimationFrame をはじめて見たので調べていたら、setTimeout や setInterval は requestAnimati・・・

JavaScript

書籍「小さなチーム、大きな仕事」からピックアップ

6年ぶりに読み返したが、今なおハッとさせられることが多く見つかる。 この本で忘れないようにしたい項目をピックアップするだけでも役に立ちそ・・・

起業向け情報

書籍「完全網羅 起業成功マニュアル」からピックアップ

この記事では、以前に読んだ際に付箋を付けていたが、その部分だけを備忘録としてピックアップするため、本の要約ではない。実際は、何倍も濃い内容で、練・・・

起業向け情報

書籍「はじめの一歩を踏み出そう」から気になったフレーズをピックアップ

もう一回、全部読み返したいところだが、書籍がありすぎるので、当時付箋紙をつけていたところだけをピックアップ。書籍内ではより具体的な説明があるので・・・

起業向け情報

書籍「起業して3年以上「続く人」と「ダメな人」の習慣」からフレーズ・ピックアップ

この記事でメモしたのは、6年前に独立したときに読んだ箇所に付箋紙をつけていたところで、本の中の一部。起業家資質かどうか知る意味で読んでも面白いと・・・

起業向け情報

書籍「金持ち父さんの起業する前に読む本」を読んで

従業員という働き方ではない道を選ぶ前に読んでおきたい本。独立するときに読んだが、そのときに付箋紙がたくさん付いていたので、その部分を備忘録として・・・

起業向け情報

大きなインパクトを世界に与え続けてきた企業=ビジョナリー・カンパニーに学ぶ

この記事は、名著「ビジョナリー・カンパニー」から見直したいと思った箇所を備忘録として書き記す。 十二の崩れた神話 下記は、ビジョナ・・・

起業向け情報

ビジョナリー・カンパニーの基本理念

この記事は、名著「ビジョナリー・カンパニー」にて、実際のビジョナリー・カンパニーの基本理念が紹介されていたので抜粋。基本理念をつくる上での参考に・・・

起業向け情報

人気の記事

iOS Safariで絶対配置(position:fixed)して惰性スクロールしてもロックしない、フリーズ回避方法

iPhoneやiPadで position: fixed; で絶対配置したエリア内をスクロールするとき、最上部をより上にスクロールしようとしたり、最下部をより・・・

JavaScript2021年4月28日

WP_Queryを使って絞り込み検索するのにコレは便利!

めっちゃ参考になるページを見つけた。 絞り込みをするたびに色々ググっていたが、これがあればほとんどのことが解決できそうな気がする。 参考: これは便利!Word・・・

WordPress2018年10月11日

Instagram API を使ってインスタに投稿した画像データを取得する

インスタに投稿した画像を自動でホームページでも更新されるようにしたい。もっとも簡単に実現する方法を紹介する。 公式リファレンスInstagram・・・

API2021年2月22日

overflowをautoにした要素のスクロール位置を変更する → scrollTop scrollLeft

まずはサンプル。 これは、overflowをautoにした要素のスクロール位置を変更するサンプルです。 これは、overflowをautoにした要素のスクロ・・・

JavaScript2017年7月19日

iframeの高さを自動調整する

iframeで呼び出した際、iframe自体はスクロールさせずに高さを取得してiframe全体を表示させます。 サンプル:iframeの高さを自動調整するデモ・・・

JavaScript2015年3月17日

WordPressのカテゴリー一覧ページでカテゴリー名とスラッグを取得する → get_queried_object()

やりたいこと カテゴリー一覧ページで、そのカテゴリー一覧ページに属する記事一覧を取得するためにループさせるのとは別に、タイトルやカテゴリー別にデザインを変・・・

WordPress2019年2月11日

配列の重複を削除する

配列の場合 /** * 配列の重複を削除する * * @param {array} ary* * @return {array} 処理後のary・・・

JavaScript2020年12月14日

イラストレーターでレイヤーごとにPNGで書き出す

【2020年07月13日】 macOS Catalina(10.15.5) / Adobe iLLustrator 2020(24.2.1) にて動作確認済・・・

Illustorator2018年2月2日

favicon.icoをWordPressの管理画面からアップロードできない→ wp-config.php を一時的に修正

いつもは直接アップロードしているので気にしていなかったが、WordPress管理画面のメニュー「メディア」からfavicon.icoをアップロードしようとした・・・

WordPress2020年8月4日

http://localhost:8888/ → http://localhost/

http://localhost:8888/ での参照ではなく、http://localhost/ で参照できるようにします。 MAMPの設定を変更する M・・・

MAMP2015年2月3日

コメントありの記事

えっ!?Yahooの検索結果から遷移しようとしたら全く違うサイトにリダイレクトされてしまった...

「>前田さん コメントありがとうございます。 環境は分かりかねますが、修正したいファイルのパーミッションを604や644に変更すると書き込みできるようになりま・・・」

お仕事・制作日記

Sony Eマウント フルサイズ対応のカメラレンズを収集するページを作ってみた

「レンズ情報追加しました 150-600mm F5-6.3 DG DN OS | Sports 超望遠レンズ。一本は持ってみたい!」

お仕事・制作日記

記事の投稿IDなどの投稿者(ユーザー)情報を取得する方法 → get_the_author_meta

「アバターを取得する「get_avatar」についても追記しました!」

WordPress

jQueryでformを操る【nameの値を取得する/クリアする】

「「値をクリアする」を追加しました。チェックボックスやラジオボタンの値を何も選択していない状態に戻すときについて触れています。」

JavaScript

iframeの高さを自動調整する

「>匿名さん コメントありがとうございます。 サンプルでは、beforeは何も処理していないので期待する表示にならない、で正解です。 クリックした後が、対応・・・」

JavaScript

Instagram API を使ってインスタに投稿した画像データを取得する

「コメントに嬉しいお言葉、ありがとうございます!」

API

MAMPでMySQL Serverが突然起動しなくなった時 → ログファイル削除

「(匿名)さん コメントありがとうございます。何も設定変更していないのに、それまで使用できていたサーバーが突然使えなくなるのは辛いですよね、、。 ここで紹介したや・・・」

MAMP

イラストレーターでレイヤーごとにPNGで書き出す

「コメントありがとうございます! そもそもできるかはわかりませんが、ソースを書き換える必要はあります。 下記記事などが参考になるかもしれません。 illustra・・・」

Illustorator

05_各種キーワードツール

「公開から14年振りの更新w デッドリンクを削除しました。ツール系は「SEO対策に役立つ便利ツール」に集約します。」

SEO

WP_Queryを使って絞り込み検索するのにコレは便利!

「「特定の「タイプ」に関連付けられた投稿を表示する場合」を一つの場合を追記し、複数の場合と分けました。」

WordPress

WEB制作マークアップJavaScriptsetTimeout は requestAnimationFrame に変えるべき? | シンプルシンプルデザイン