例えば、ページiには、多くのコンポーネント、多くのコンポーネントの配列があります。 いくつかのアクションをディスパッチすると、このコンポーネントのすべての配列を持つページ全体が再レンダリングされます。 しかし、私はページ上の変更されたアイテム/コンポーネントを再レンダリングする必要はありません。 変更されたコンポーネントのみを再レンダリングします。私はshouldComponentUpdate()があることを知っています。しかし、すべてのコンポーネントにshouldComponentUpdateをロジックを書くことはそれほどクールではありません。おそらく、これにはいくつかのライブラリがありますか、あるいはいくつかの方法がありますか?私はreactjs/reselect
について聞いたことがありますか、そのような問題のために正しいことです、または私が誤解した場合は、再選択の略号を教えてください?機能コンポーネントを使用する場合はどうなりますか?React + redux、コンポーネントの配列。この配列から変更されたコンポーネントだけを再レンダリングする方法は?
おそらく、パフォーマンスを最適化し、再構築を許可するコンポーネントを制御するための別のライブラリがありますか?
また、https://github.com/seatgeek/react-infinitehttps://github.com/bvaughn/react-virtualizedも見つかりました。これらの2つのライブラリを同じ目的で使用しますか?違いは何ですか?どちらを選択するのですか?
簡単な質問ですが、データをフェッチしていると仮定して配列に追加しています。 新しい項目を取得するたびに、配列全体ではなく、追加された項目だけをレンダリングする方法はありますか?
また、https://github.com/seatgeek/react-infinite https://github.com/bvaughn/react-virtualizedも見つかっています。これらは同じ問題で同じことをしますか?差異とは何ですか? –
私は反応仮想化や反応無限大を混乱させたことはありませんでしたが、私の検索では、非常に特殊な使用事例のライブラリと思われます。再選択は主にReduxストア用の「セレクタ」ライブラリです。意味することは、メモを取るデータの特定の部分を選択することができます。これについて私を引用してはいけませんが、リアクション仮想化ルックスは、特定のコンポーネントのビジュアルコンポーネントを必要になるまで実質的にレンダリングするための特殊なライブラリにすぎません。 – Jay
Reduxの仕組みは、あなたのコンポーネントを使ってあなたの店にあなたの店を接続することです(ビッグデータオブジェクトと考える)。しかし、店舗が変わるたびに、Reactjsはあなたのアプリを再作成します。これは、あなたのデータの変化とはまったく無関係なアップデートのために、あなたのアプリの不要な部分が再レンダリングされることを意味します。再選択は、データ(店舗)を「メモする」ことでこれと戦うために使用されます。 – Jay