[解決済み] 違反 長い JavaScript タスクの実行に xx ms かかりました。
質問
最近、このような警告を受けたのですが、初めてです。
<ブロッククオート[Violation] Long running JavaScript task took 234ms
[Violation] Forced reflow while executing JavaScript took 45ms
グループプロジェクトに取り組んでいるが、どこからがそうなのかさっぱりわからない。以前はこんなことはなかったのに。突然、他の誰かがプロジェクトに参加したときに現れました。この警告を引き起こすファイルや関数を見つけるにはどうすればいいのでしょうか?私は答えを探していますが、ほとんどは解決方法に関する解決策についてです。問題の原因も見つけられないのに、解決できるわけがない。
この場合、Chromeでのみ警告が表示されます。Edgeでも試してみましたが、同様の警告は出ませんでしたし、Firefoxではまだテストしていません。
からもエラーが出るんです。
jquery.min.js
:
[Violation] Handler took 231ms of runtime (50ms allowed) jquery.min.js:2
解決方法は?
更新情報 : Chrome 58+では、デフォルトでこれらのメッセージや他のデバッグメッセージが非表示になっています。表示するには、「情報」の隣にある矢印をクリックし、「詳細」を選択します。
Chrome 57では、デフォルトで「違反の非表示」がオンになっています。これを元に戻すには、フィルターを有効にして、「違反の非表示」ボックスのチェックを外す必要があります。
<ブロッククオートプロジェクトに関わる誰かが突然表示される
Chrome56にアップデートした可能性が高いのでは?この警告は素晴らしい新機能だと私は思います。どうしても消したいときだけ消してください。評価者に点数を取られてしまいますよ。根本的な問題は他のブラウザにもありますが、ブラウザはあなたに問題があることを伝えていないだけなのです。Chromium のチケットは こちら しかし、この件に関して興味深い議論はありません。
これらのメッセージは、実際には大きな問題を引き起こさないため、エラーではなく警告となっています。フレームが落ちたり、スムーズでない体験の原因になるかもしれません。
しかし、アプリケーションの品質を向上させるために調査し、修正する価値はあります。その方法は、どのような状況でメッセージが表示されるかに注意を払い、パフォーマンステストを行って問題が発生している場所を絞り込むことです。パフォーマンステストを始める最も簡単な方法は、次のようなコードを挿入することです。
function someMethodIThinkMightBeSlow() {
const startTime = performance.now();
// Do the normal stuff for this function
const duration = performance.now() - startTime;
console.log(`someMethodIThinkMightBeSlow took ${duration}ms`);
}
もっと高度なことをしたいのであれば、次のような方法もあります。 Chromeのプロファイラ のようなベンチマーク・ライブラリーを利用することもできます。 これ .
時間がかかっているコードを見つけたら(Chromeのしきい値は50ms)、いくつかのオプションがあります。
- 不要と思われるタスクの一部または全部をカットする。
- 同じ作業をより速く行う方法を見つけ出す
- コードを複数の非同期ステップに分割する
(1)と(2)は難しいか不可能かもしれませんが、時には本当に簡単なこともあるので、最初の試みとすべきです。必要であれば、(3)は常に可能であるべきです。これを行うには、次のようなものを使用します。
setTimeout(functionToRunVerySoonButNotNow);
または
// This one is not available natively in IE, but there are polyfills available.
Promise.resolve().then(functionToRunVerySoonButNotNow);
JavaScriptの非同期性については、こちらをご覧ください。 こちら .
関連
-
[解決済み] Uncaught Invariant Violation: 前のレンダリング中よりも多くのフックをレンダリングした
-
[解決済み】webpack: モジュールが見つかりません。Error: 解決できない(相対パスで)
-
[解決済み] JavaScriptで "use strict "は何をするのか、その根拠は?
-
[解決済み] JavaScriptで文字列が部分文字列を含むかどうかを確認する方法は?
-
[解決済み] あるJavaScriptファイルを他のJavaScriptファイルにインクルードするにはどうすればよいですか?
-
[解決済み] JavaScriptでオブジェクトをディープクローンする最も効率的な方法は何ですか?
-
[解決済み] JavaScriptで要素のクラスを変更するにはどうすればよいですか?
-
[解決済み】JavaScriptの比較では、どちらの等号演算子(== vs ===)を使うべきですか?
-
[解決済み】JavaScriptで文字列の出現箇所をすべて置換する方法
-
[解決済み】オブジェクトからプロパティを削除する(JavaScript)
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】SecurityError: オリジンを持つフレームがクロスオリジンフレームにアクセスするのをブロックした
-
[解決済み] 解決済み】clearInterval()が動作しない [重複] [重複]
-
[解決済み】Javascriptのコールバック関数がFirefoxで「Callback is not a function」というエラーを投げる
-
[解決済み】「Uncaught TypeError: Chromeで "Illegal invocation "が発生する。
-
[解決済み】ある要素が可視DOMに存在するかどうかを確認するにはどうすればいいですか?
-
[解決済み】Javascript - ERR_CONTENT_LENGTH_MISMATCH
-
[解決済み】JS ファイルが net::ERR_ABORTED 404 (Not Found) を取得する)
-
[解決済み】Jestが予期しないトークンに遭遇した
-
[解決済み】PhantomJS 2.1.1を使用してReactJSアプリケーションをレンダリングできない理由とは?
-
[解決済み】Javascript、[オブジェクトHTMLInputElement]を表示中。]