ホームページ >ウェブフロントエンド >jsチュートリアル >上級レベル: React でのイベントの処理
上級開発者として、React のイベント処理を深く理解していることが期待されます。これには、基本を理解するだけでなく、効率的で保守可能でスケーラブルなアプリケーションを作成するための高度なテクニックを習得することも含まれます。この記事では、イベント ハンドラーの追加、合成イベントの理解、イベント ハンドラーへの引数の受け渡し、カスタム イベントの作成、イベント委任の活用など、React でのイベント処理の複雑さについて説明します。
JSX でのイベント ハンドラーの追加は簡単で、通常の HTML でのイベントの処理に似ていますが、React の独自のアーキテクチャによる重要な違いがいくつかあります。
イベントハンドラーの追加例:
import React from 'react'; const handleClick = () => { console.log('Button clicked!'); }; const App = () => { return ( <div> <button onClick={handleClick}>Click Me</button> </div> ); }; export default App;
この例では、ボタンがクリックされるたびに handleClick 関数が呼び出されます。 JSX の onClick 属性は、イベント ハンドラーを指定するために使用されます。
React は合成イベントと呼ばれるシステムを使用してイベントを処理します。合成イベントは、ブラウザーのネイティブ イベント システムのクロスブラウザー ラッパーです。これにより、イベントが異なるブラウザ間で一貫して動作することが保証され、統一された API が提供されます。
合成イベントの例:
import React from 'react'; const handleInputChange = (event) => { console.log('Input value:', event.target.value); }; const App = () => { return ( <div> <input type="text" onChange={handleInputChange} /> </div> ); }; export default App;
この例では、handleInputChange 関数は、入力フィールドの値が変更されるたびにその値を記録します。イベント パラメーターは、すべてのブラウザーにわたって一貫したイベント プロパティを提供する合成イベントです。
イベント ハンドラーへの引数の受け渡しは、アロー関数またはバインド メソッドを使用して行うことができます。これは、より柔軟な方法でイベントを処理するために重要です。
アロー関数を使用した例:
import React from 'react'; const handleClick = (message) => { console.log(message); }; const App = () => { return ( <div> <button onClick={() => handleClick('Button clicked!')}>Click Me</button> </div> ); }; export default App;
bind メソッドを使用した例:
import React from 'react'; const handleClick = (message) => { console.log(message); }; const App = () => { return ( <div> <button onClick={handleClick.bind(null, 'Button clicked!')}>Click Me</button> </div> ); }; export default App;
どちらのメソッドでも、追加の引数を handleClick 関数に渡すことができるため、イベント処理が柔軟になります。
React でのカスタム イベントの作成は、標準イベントではカバーされないより複雑なインタラクションに必要です。カスタム イベントは、CustomEvent コンストラクターとdispatchEvent メソッドを使用して作成およびディスパッチできます。
カスタム イベントの作成とディスパッチの例:
import React, { useEffect, useRef } from 'react'; const CustomEventComponent = () => { const buttonRef = useRef(null); useEffect(() => { const handleCustomEvent = (event) => { console.log(event.detail.message); }; const button = buttonRef.current; button.addEventListener('customEvent', handleCustomEvent); return () => { button.removeEventListener('customEvent', handleCustomEvent); }; }, []); const handleClick = () => { const customEvent = new CustomEvent('customEvent', { detail: { message: 'Custom event triggered!' }, }); buttonRef.current.dispatchEvent(customEvent); }; return ( <button ref={buttonRef} onClick={handleClick}> Trigger Custom Event </button> ); }; export default CustomEventComponent;
この例では、customEvent という名前のカスタム イベントが作成され、ボタンがクリックされたときに送出されます。イベント ハンドラーはカスタム イベントをリッスンし、イベントの詳細メッセージをログに記録します。
イベント委任は、単一のイベント リスナーを使用して複数の要素のイベントを管理する手法です。これは、リストやテーブルでイベントを効率的に管理する場合に特に便利です。
イベント委任の例:
import React from 'react'; const handleClick = (event) => { if (event.target.tagName === 'BUTTON') { console.log(`Button ${event.target.textContent} clicked!`); } }; const App = () => { return ( <div onClick={handleClick}> <button>1</button> <button>2</button> <button>3</button> </div> ); }; export default App;
この例では、div 要素の単一のイベント ハンドラーがすべてのボタンのクリック イベントを管理します。イベント ハンドラーは、event.target をチェックしてどのボタンがクリックされたかを判断し、それに応じてメッセージを記録します。
const App = () => { const handleClick = () => { console.log('Button clicked!'); }; return ( <div> <button onClick={handleClick}>Click Me</button> </div> ); };
const handleSubmit = (event) => { event.preventDefault(); // Handle form submission }; return <form onSubmit={handleSubmit}>...</form>;
useEffect(() => { const handleResize = () => { console.log('Window resized'); }; window.addEventListener('resize', handleResize); return () => { window.removeEventListener('resize', handleResize); }; }, []);
const debounce = (func, delay) => { let timeoutId; return (...args) => { clearTimeout(timeoutId); timeoutId = setTimeout(() => { func.apply(null, args); }, delay); }; }; useEffect(() => { const handleScroll = debounce(() => { console.log('Scroll event'); }, 300); window.addEventListener('scroll', handleScroll); return () => { window.removeEventListener('scroll', handleScroll); }; }, []);
const List = () => { const handleClick = (event) => { if (event.target.tagName === 'LI') { console.log(`Item ${event.target.textContent} clicked!`); } }; return ( <ul onClick={handleClick}> <li>Item 1</li> <li>Item 2</li> <li>Item 3</li> </ul> ); };
React でイベントを効率的に処理することは、インタラクティブで高性能なアプリケーションを作成するために重要です。イベント ハンドラーの追加、合成イベントの使用、イベント ハンドラーへの引数の受け渡し、カスタム イベントの作成、イベント委任の活用などのテクニックを習得することで、堅牢でスケーラブルなアプリケーションを構築できます。ベスト プラクティスを実装すると、コードが複雑になっても保守性とパフォーマンスが維持されます。上級開発者として、これらの高度なテクニックを活用する能力は、プロジェクトの成功とチームの有効性に大きく貢献します。
以上が上級レベル: React でのイベントの処理の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。