ホームページ ウェブフロントエンド jsチュートリアル 仮想 DOM への単純な更新からの DOM 操作

仮想 DOM への単純な更新からの DOM 操作

Jan 09, 2025 am 06:39 AM

TLDR

導入

Web アプリケーションを構築する場合、開発者が直面する最も基本的な課題の 1 つは、ユーザーの操作や状態の変化に応じてドキュメント オブジェクト モデル (DOM) を効率的に更新することです。 todo アプリケーションの 3 つの異なる実装を調べて、この概念を探ってみましょう。それぞれが DOM 操作に対する異なるアプローチを示しています。

DOM Manipulation from Simple Updates to Virtual DOM

Github: https://github.com/sreeharsha-rav/javascript_projects/blob/main/todo-app/README.md

DOM アップデートの進化

1. DOM の直接操作: シンプルなアプローチ

最初の実装では、変更が発生するたびに DOM を直接操作するという最も単純なアプローチを使用しました。新しい Todo の追加を処理する方法の簡略版は次のとおりです。

function addTodo() {
    const todoText = input.value;
    const todoElement = document.createElement('div');
    todoElement.textContent = todoText;
    todoList.appendChild(todoElement);
}
ログイン後にコピー

このアプローチは直感的で、単純なアプリケーションにはうまく機能しますが、次のような制限があります。

  • 各操作は DOM に直接触れます
  • アプリケーションの状態を追跡する中央の場所がありません
  • 複数の更新間で一貫性を維持するのが困難
  • 頻繁に更新すると非効率になる可能性があります

2. 状態ベースの DOM 操作: 構造の追加

2 番目の実装では、状態管理の概念が導入されました。 DOM を直接操作する代わりに、中央の状態を維持し、その状態に基づいて DOM を更新しました。

const todoStore = new Map();

function addTodo(text) {
    // Update state
    const id = nextId++;
    todoStore.set(id, {
        text,
        completed: false
    });

    // Update DOM
    const todoElement = createTodoElement(text, id);
    todoList.appendChild(todoElement);
}
ログイン後にコピー

このアプローチにより、いくつかの改善がもたらされました。

  • データ (状態) とプレゼンテーション (DOM) を明確に分離
  • アプリケーションの動作がより予測可能になりました
  • 元に戻す/やり直しなどの機能の実装が簡単になりました
  • コードのより良い構成

しかし、DOM の更新が効率的であることを確認し、状態と UI の間の一貫性を維持するという課題に直面しました。

3. 仮想 DOM のようなアプローチ: スマート アップデート

私たちの最終実装では、状態の差分を使用した単純な仮想 DOM のようなメカニズムが導入されました。このアプローチは、洗練度における大幅な飛躍を表します:

let todoState = [];      // Current state
let oldTodoState = [];   // Previous state

function updateState(newTodos) {
    // Find what changed
    const added = newTodos.filter(newTodo => 
        !oldTodoState.some(oldTodo => oldTodo.id === newTodo.id)
    );
    const deleted = oldTodoState.filter(oldTodo => 
        !newTodos.some(newTodo => newTodo.id === oldTodo.id)
    );
    const updated = // ... find updated items

    // Update only what changed
    added.forEach(todo => addTodoElement(todo));
    deleted.forEach(todo => removeTodoElement(todo));
    updated.forEach(todo => updateTodoElement(todo));

    // Save current state for next comparison
    oldTodoState = [...newTodos];
}
ログイン後にコピー

調整と相違について理解する

React によって普及した調整の概念は、望ましい状態に一致するように DOM を効率的に更新することです。私たちの単純な実装は、次の 3 つの重要な側面を示しています。

1. 状態の比較

私たちは、現在と以前の 2 つのバージョンの状態を維持しています。これにより、更新間で何が変更されたかを正確に検出できます。これらの違いを見つけるプロセスは「差分」と呼ばれます。

2. 最小限のアップデート

すべてを再構築するのではなく、変更された部分のみを更新します。

  • 新しい項目が DOM に追加されます
  • 削除された項目は DOM から削除されます
  • 変更されたアイテムはその場で更新されます

3. バッチ処理

すべての差分を計算した後、DOM の更新はすべて 1 回のパスで行われます。これは、変更が発生したときに一度に 1 つずつ更新するよりも効率的です。

スマート DOM 操作の利点

これらの実装を進めるにつれて、いくつかの利点が得られました。

  1. パフォーマンス: 変更された部分のみを更新することで、コストのかかる DOM 操作を最小限に抑えます。
  2. 予測可能性: 単一の真実の情報源 (状態) があれば、アプリケーションの理解とデバッグが容易になります。
  3. スケーラビリティ: アプリケーションが成長しても、差分アプローチは引き続き効率的です。
  4. 保守性: 懸念事項を明確に分離することで、コードの理解と変更が容易になります。

現実世界への影響

私たちの実装は簡素化されていますが、React のような最新のフロントエンド フレームワークの背後にある中心的な概念を示しています。 React での実際の Virtual DOM 実装はより洗練されており、以下を処理します:

  • 複雑な入れ子構造
  • イベントの代表者
  • コンポーネントのライフサイクル
  • バッチ更新
  • ブラウザ間の互換性

結論

ToDo アプリケーションの進化は、DOM 操作へのさまざまなアプローチがどのようにさまざまなトレードオフを伴うかを示しています。直接操作は理解と実装が簡単ですが、状態管理とスマート アップデートを使用したより構造化されたアプローチは、より保守性と拡張性の高いアプリケーションにつながります。

調整と差分の概念は、簡略化された形であっても、React のような最新のフレームワークがなぜ非常に強力であるかを示しています。これらの複雑な更新は自動的に処理されるため、開発者は DOM 更新の最適化ではなく、機能の構築に集中できます。

Web アプリケーションがより複雑になるにつれて、これらの基本概念を理解することがますます重要になります。フレームワークを使用している場合でも、何かを最初から構築している場合でも、DOM 更新がどのように、そしてなぜそのように機能するのかを知ることで、より効率的な開発者になれます。

以上が仮想 DOM への単純な更新からの DOM 操作の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

javascriptの分解:それが何をするのか、なぜそれが重要なのか javascriptの分解:それが何をするのか、なぜそれが重要なのか Apr 09, 2025 am 12:07 AM

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

JavaScriptの進化:現在の傾向と将来の見通し JavaScriptの進化:現在の傾向と将来の見通し Apr 10, 2025 am 09:33 AM

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

JavaScriptエンジン:実装の比較 JavaScriptエンジン:実装の比較 Apr 13, 2025 am 12:05 AM

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

Python vs. JavaScript:学習曲線と使いやすさ Python vs. JavaScript:学習曲線と使いやすさ Apr 16, 2025 am 12:12 AM

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

JavaScript:Web言語の汎用性の調査 JavaScript:Web言語の汎用性の調査 Apr 11, 2025 am 12:01 AM

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

next.jsを使用してマルチテナントSaaSアプリケーションを構築する方法(フロントエンド統合) next.jsを使用してマルチテナントSaaSアプリケーションを構築する方法(フロントエンド統合) Apr 11, 2025 am 08:22 AM

この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合) next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合) Apr 11, 2025 am 08:23 AM

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

C/CからJavaScriptへ:すべてがどのように機能するか C/CからJavaScriptへ:すべてがどのように機能するか Apr 14, 2025 am 12:05 AM

C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

See all articles