DOM 更新のバッチ処理とは、ブラウザにとってコストのかかる操作である リフロー と 再描画 の数を減らす方法で、DOM に複数の変更を行うことを指します。 DOM のバッチ更新とは、Web ページの構造 (DOM) に複数の変更を 1 つずつではなく一度に行うことです。
DOM を一度に 1 つずつ変更すると、ブラウザーは変更を加えるたびに停止、位置の再計算、ページの再描画を繰り返す必要があるため、Web ページの速度が低下する可能性があります。更新をバッチ処理することで、すべての変更を組み合わせて一度に適用し、Web ページをより高速かつスムーズに作成できます。
部屋の中で家具を移動しているところを想像してみてください。椅子を 1 つ移動し、全員が気づくのを待ち、次にテーブルを移動し、また待つと、永遠に時間がかかります。ただし、すべてを一度に移動して最終結果を表示すると、プロセスがより迅速になり、中断も少なくなります。
コーディング用語で言えば、何かを追加または変更するたびに DOM を更新するのではなく、すべての変更を収集して一緒に適用するため、はるかに高速になります。
リストに項目を 1 つずつ追加する代わりに (遅い):
// Updating DOM one by one (slow) const list = document.getElementById('myList'); const newItem = document.createElement('li'); newItem.textContent = "Item 1"; list.appendChild(newItem);
すべてのアイテムを「バッチ」に収集し、すべてを一度に (高速に) 追加できます:
// Batch DOM update (fast) const list = document.getElementById('myList'); const fragment = document.createDocumentFragment(); for (let i = 1; i <= 5; i++) { const newItem = document.createElement('li'); newItem.textContent = `Item ${i}`; fragment.appendChild(newItem); } list.appendChild(fragment);
この方法では、すべての項目の準備ができた後にブラウザはページを 1 回だけ更新するため、処理がより速く、より効率的になります。
以上がDOM のバッチ更新とは何ですか?なぜそれが役立つのですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。