JavaScript オブザーバーは、開発者がオブジェクト、イベント、またはデータ ストリームの変更に対応できるようにすることで、動的アプリケーションを作成するために不可欠です。このガイドでは、さまざまな JavaScript オブザーバーの種類について、詳細な説明と実践的な例を交えて説明します。
イベント リスナーは基本的な JavaScript オブザーバーであり、ユーザー インタラクション (クリック、キーの押下、マウスの動き) などのイベントに反応します。
<code class="language-javascript">// Select a button const button = document.querySelector('button'); // Add a click listener button.addEventListener('click', (event) => { console.log('Button clicked!', event); }); // Add a mouseover listener button.addEventListener('mouseover', () => { console.log('Mouse over button!'); });</code>
ミューテーション オブザーバーは、動的に更新されるコンテンツに不可欠な DOM の変更 (ノードの追加、削除、または変更) を追跡します。
<code class="language-javascript">// Target node const targetNode = document.querySelector('#target'); // Create a MutationObserver const observer = new MutationObserver((mutationsList) => { mutationsList.forEach((mutation) => { console.log('DOM change detected:', mutation); }); }); // Configuration const config = { childList: true, attributes: true, subtree: true }; // Start observing observer.observe(targetNode, config); // Simulate a change setTimeout(() => { const newElement = document.createElement('p'); newElement.textContent = 'New text!'; targetNode.appendChild(newElement); }, 2000);</code>
要素がビューポートに出入りするときを検出する交差点オブザーバーは、遅延読み込みやアニメーションに最適です。
<code class="language-javascript">// Element to observe const targetElement = document.querySelector('#box'); // Create an IntersectionObserver const observer = new IntersectionObserver((entries) => { entries.forEach((entry) => { if (entry.isIntersecting) { console.log('Element in viewport:', entry.target); } else { console.log('Element out of viewport:', entry.target); } }); }); // Start observing observer.observe(targetElement);</code>
サイズ変更オブザーバーは、応答性の高い UI にとって重要な要素サイズの変化を監視します。
<code class="language-javascript">// Element to observe const box = document.querySelector('#resizable'); // Create a ResizeObserver const observer = new ResizeObserver((entries) => { entries.forEach((entry) => { const { width, height } = entry.contentRect; console.log(`New size: ${width}px x ${height}px`); }); }); // Start observing observer.observe(box); // Simulate a resize setTimeout(() => { box.style.width = '400px'; box.style.height = '200px'; }, 2000);</code>
プロキシ API を使用すると、オブジェクトのプロパティの変更を監視でき、更新に対する動的な反応が可能になります。
<code class="language-javascript">// Object to observe const obj = { name: 'John', age: 30 }; // Use Proxy const observedObj = new Proxy(obj, { set(target, property, value) { console.log(`Property '${property}' changed from '${target[property]}' to '${value}'`); target[property] = value; return true; }, }); // Trigger changes observedObj.name = 'Jane'; observedObj.age = 31;</code>
RxJS は、効率的なデータ ストリーム管理のための高度なオブザーバー パターンの実装を提供します。
<code class="language-javascript">// Select a button const button = document.querySelector('button'); // Add a click listener button.addEventListener('click', (event) => { console.log('Button clicked!', event); }); // Add a mouseover listener button.addEventListener('mouseover', () => { console.log('Mouse over button!'); });</code>
パフォーマンス オブザーバーは、アプリケーションの最適化のためにパフォーマンス イベント (リソースの読み込み、長いタスク) を追跡します。
<code class="language-javascript">// Target node const targetNode = document.querySelector('#target'); // Create a MutationObserver const observer = new MutationObserver((mutationsList) => { mutationsList.forEach((mutation) => { console.log('DOM change detected:', mutation); }); }); // Configuration const config = { childList: true, attributes: true, subtree: true }; // Start observing observer.observe(targetNode, config); // Simulate a change setTimeout(() => { const newElement = document.createElement('p'); newElement.textContent = 'New text!'; targetNode.appendChild(newElement); }, 2000);</code>
組み込み API を超えるシナリオ向けに、オブザーバー設計パターンを使用してカスタム オブザーバーを作成します。
<code class="language-javascript">// Element to observe const targetElement = document.querySelector('#box'); // Create an IntersectionObserver const observer = new IntersectionObserver((entries) => { entries.forEach((entry) => { if (entry.isIntersecting) { console.log('Element in viewport:', entry.target); } else { console.log('Element out of viewport:', entry.target); } }); }); // Start observing observer.observe(targetElement);</code>
JavaScript オブザーバーは、動的で応答性の高いアプリケーションを構築するための強力なツールです。 これらのさまざまなタイプをマスターすると、JavaScript の開発能力が大幅に向上します。 これらの例を試して理解を深め、プロジェクトに組み込んでください。
以上がJavaScript のオブザーバーを理解する: 包括的なガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。