イベント バスは React で使用できます。React はコンポーネント間のイベント転送を解決するためにイベント バスを使用します。一般的に使用されるライブラリ イベントを使用して、対応する操作を完了できます。npm または Yarn を使用してインストールできます. events の構文は「npm install events」と「yarn add events」です。
このチュートリアルの動作環境: Windows 10 システム、react17.0.1 バージョン、Dell G3 コンピューター。
reactでイベントバスが使えるようになる
reactイベントバスで解決できる問題:コンポーネント間のイベント送信
問題がある場合React 開発でコンポーネント間でイベントを転送するにはどうすればよいですか?
A. Vue では、Vue のインスタンスを通じてイベント バス (EventBus) をすばやく実装して操作を完了できます;
B. React では、一般的に使用されるライブラリを利用できます対応する操作を完了するためのイベント;
実装方法
サードパーティ ライブラリ イベントを使用して実装する
共通 API
EventEmitter オブジェクトの作成:eventBus オブジェクト
イベントの発行:eventBus.emit("イベント名", パラメーター リスト)
イベントのリッスン:eventBus.addListener("event name", listen 関数)
イベントの削除:eventBus.removeListener("イベント名", listen 関数)
使用前にインストールする必要があります。次の 2 つの方法のいずれかを選択します
npm install events yarn add events
events の練習:
まず、新しいファイル QcEventEmitter.js を作成します。ファイルの内容は次のとおりです:
import { EventEmitter } from 'events' class QcEventEmitter extends EventEmitter {}; export default new QcEventEmitter();
以下は、イベントを渡す EventTest コンポーネントを実装します。 Person コンポーネント:
EventTest ファイルのコンテンツ
A. QcEventEmitter を EventTest コンポーネントに導入します
B. クリック イベント
import React, { Component } from 'react'; import QcEventEmitter from 'common/utils/QcEventEmitter' class EventTest extends Component { render() { return ( <div> <button onClick={e => this.btnCLick()}>测试event事件</button> </div> ); } btnCLick(){ QcEventEmitter.emit('contextClick', 'Lucy', '99') } }# の QcEventEmitter.emit を通じてイベントを送信します##デフォルトの EventTest をエクスポート;パーソン ファイルの内容 A. QcEventEmitter は Person コンポーネントに導入されています。B.ComponentDidMount の QcEventEmitter.addListener を通じてイベントをリッスンします。
##C.componentWillUnmount の QcEventEmitter.removeListener に移動します。イベントの監視に加えて、
import React, { Component, useContext } from 'react'; import QcEventEmitter from 'common/utils/QcEventEmitter' class Person extends Component { componentDidMount(){ QcEventEmitter.addListener("contextClick", this.headerClick) } componentWillUnmount() { QcEventEmitter.removeListener("contextClick", this.headerClick) } headerClick(name, age) { console.log(name, age); } render() { return ( <div> <h2 id="这是Person子组件">这是Person子组件</h2> </div> ); } } export default Person;
App.js ファイルで EventTest コンポーネントと Person コンポーネントをレンダリングします (Person コンポーネントがレンダリングされた後、 EventTest によって発行されたイベントをリッスンでき、それらの間の依存関係は必要ありません)
import React from 'react'; import ContetTest from './pages/contenxt' import Person from 'pages/contenxt/person' function App() { return ( <div className="App"> <ContetTest /> <Person /> </div> ); } export default App;
【関連する推奨事項:
JavaScript ビデオ チュートリアル以上がイベントバスは反応で使用できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

tonavigatereAct'somplexEcosystemively、理解を理解し、認識していることを認識していることを認識しているandweakness、およびIntegreatemtoemtoemtoemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemtemotereconceptate、その後、勾配内で測定する

RactuseSeSeSeSeSeSeSeSpiffictifideidifiedItemsbyprovidingastableidentitytoeeedelement.1)keysallowReactTotTotTotTotTotTotTotTotTotTotTotTotTotTotTotRACKESOUTRE-RENDERINGTHEENTERELIST.2)chookiniqueandstablekeys、avolididingArrayIndices.3)reforceAsificlySificlySiflovedobrovesiondanc

KeysinReactarecrucialforoptimizingTherenderingProcessandDynamicListseffective.tospotandfixkey-relatedissues:1)adduniquekeystolistiTemstoavoidsissusisus、2)useuniqueidideididifiersfromdateadceSofofordiceys、3)

Reactの一元配置データバインディングにより、データが親コンポーネントから子コンポーネントに流れることが保証されます。 1)データは単一に流れ、親コンポーネントの状態の変化は子コンポーネントに渡すことができますが、子コンポーネントは親コンポーネントの状態に直接影響することはできません。 2)この方法により、データフローの予測可能性が向上し、デバッグとテストが簡素化されます。 3)制御されたコンポーネントとコンテキストを使用することにより、一方向のデータストリームを維持しながら、ユーザーの相互作用とコンポーネント間通信を処理できます。

keysinReactarecrucialforeffiencedomupdatessandRecOnciliation.1)選択可能でユニークな、そして類似のフルキーなど、Itemids.2)fornestedLists、useuniquekeysateachlevel.3)

useState()uscrucialforoptimizingRectperformanceduetuitsoitsimpactonre-rendersandupdates.tooptimize:1)useusecallbacktomoize funtionsandpreventunnederireRenders.2)

コンテキストとユーザーを使用して、大規模なReactアプリケーションで州の管理を簡素化できるため、状態を共有します。 1)プロップドリルを減らす、2)より明確なコード、3)グローバルな状態を管理しやすい。ただし、パフォーマンスのオーバーヘッドと複雑さのデバッグに注意してください。コンテキストと最適化技術の合理的な使用は、アプリケーションの効率と保守性を向上させることができます。

誤ったキーを使用すると、Reactアプリケーションでパフォーマンスの問題や予期しない動作を引き起こす可能性があります。 1)キーはリスト項目の一意の識別子であり、Virtual Domを効率的にReactの更新を支援します。 2)同じまたは非ユニークなキーを使用すると、リスト項目が再注文され、コンポーネント状態が失われます。 3)キーとして安定した一意の識別子を使用すると、パフォーマンスを最適化し、完全な再レンダリングを回避できます。 4)ESLINTなどのツールを使用して、キーの正しさを確認します。キーを適切に使用すると、効率的で信頼性の高い反応アプリケーションが保証されます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

メモ帳++7.3.1
使いやすく無料のコードエディター

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

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

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ホットトピック









