使用store來優化React元件
本文主要介紹了使用store來優化React元件的方法,小編覺得還挺不錯的,現在分享給大家,也給大家做個參考。一起跟著小編過來看看吧,希望能幫助大家。
在使用 React 編寫元件的時候,我們常常會碰到兩個不同的元件之間需要共享狀態情況,而通常的做法就是提升狀態到父元件。但是這樣做會有一個問題,就是儘管只有兩個元件需要這個狀態,但是因為把狀態提到了父元件,那麼在狀態變化的時候,父元件以及其下面的所有子元件都會重新render,如果你的父組件比較複雜,包含了其他很多子組件的話,就有可能造成效能問題。
Redux 透過把狀態放在全域的store 裡,然後元件去訂閱各自需要的狀態,當狀態改變的時候,只有那些訂閱的狀態改變的元件才重新render,這樣就避免了上面所說的提升狀態所帶來的副作用。但是,當我們在寫一個 React 元件庫的時候,redux 加 react-redux 的組合可能就有點太重了。所以我們可以自己寫一個簡單的 store,來實作類似 Redux 的訂閱模式。
參考Redux 的實作來寫一個簡版的createStore:
function createStore(initialState) { let state = initialState; const listeners = []; function setState(partial) { state = { ...state, ...partial, }; for (let i = 0; i < listeners.length; i++) { listeners[i](); } } function getState() { return state; } function subscribe(listener) { listeners.push(listener); return function unsubscribe() { const index = listeners.indexOf(listener); listeners.splice(index, 1); }; } return { setState, getState, subscribe, }; }
我們的createStore 很簡單,算上空行也只有33 行,總共暴露了3 個方法,沒有Redux 裡的dispatch 和reducer,直接透過setState 方法改變狀態。下面我們來用它一個計數器的例子。
class Counter extends React.Component { constructor(props) { super(props); // 初始化 store this.store = createStore({ count: 0, }); } render() { return ( <p> <Buttons store={store} /> <Result store={store} /> </p> ) } } class Buttons extends React.Component { handleClick = (step) => () => { const { store } = this.props; const { count } = store.getState(); store.setState({ count: count + step }); } render() { return ( <p> <button onClick={this.handleClick(1)}>+</button> <button onClick={this.handleClick(1)}>-</button> </p> ); } } class Result extends React.Component { constructor(props) { super(props); this.state = { count: props.store.getState().count, }; } componentDidMount() { this.props.store.subscribe(() => { const { count } = this.props.store.getState(); if (count !== this.state.count) { this.setState({ count }); } }); } render() { return ( <p>{this.state.count}</p> ); }; }
範例中Buttons 裡透過store.setState 來改變store 中的狀態,並不會造成整個Counter 的重新render,但因為Result 中訂閱了store 的變化,所以當count 有變化的時候就可以透過改變自己元件內的狀態來重新render,這樣就巧妙地避免了不必須要的render。
最後,上面的createStore 雖然只有幾十行程式碼,我還是把它寫成了一個叫mini-store 庫放在GitHub 上,並且提供了類似Redux 的Provider 和connect 方法,總共加起來也就100 多行程式碼。如果你也在寫 React 元件庫,需要管理一個複雜元件的狀態,不妨試試這個最佳化方式。
相關推薦:
JS實作點擊網頁判斷是否安裝app並開啟否則跳轉app store
以上是使用store來優化React元件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

不少用戶在玩win10的的一些遊戲的時候總是會遇到一些問題,比如說卡屏和花屏等等情況,這個時候我們是可以採用打開directplay這個功能來解決的,而且功能的操作方法也很簡單。 win10舊版元件directplay怎麼安裝1、在搜尋框裡面輸入「控制台」然後開啟2、檢視方式選擇大圖示3、找到「程式與功能」4、點選左側的啟用或關閉win功能5、選擇舊版這裡的勾選上就可以了

PHP、Vue和React:如何選擇最適合的前端框架?隨著互聯網技術的不斷發展,前端框架在Web開發中起著至關重要的作用。 PHP、Vue和React作為三種代表性的前端框架,每一種都具有其獨特的特徵和優勢。在選擇使用哪種前端框架時,開發人員需要根據專案需求、團隊技能和個人偏好做出明智的決策。本文將透過比較PHP、Vue和React這三種前端框架的特徵和使

win10舊版元件是需要使用者自己去設定裡面打開的,因為很多的元件平時都是預設關閉的狀態,首先我們需要進入到設定裡面,操作很簡單,跟著下面的步驟來就可以了win10舊版元件在哪裡開啟1、點選開始,然後點選「win系統」2、點選進入控制台3、再點選下面的程式4、點選「啟用或關閉win功能」5、在這裡就可以選擇你要的開啟了

Java框架與React框架的整合:步驟:設定後端Java框架。建立專案結構。配置建置工具。建立React應用程式。編寫RESTAPI端點。配置通訊機制。實戰案例(SpringBoot+React):Java程式碼:定義RESTfulAPI控制器。 React程式碼:取得並顯示API回傳的資料。

Angular框架中元件的預設顯示行為不是區塊級元素。這種設計選擇促進了元件樣式的封裝,並鼓勵開發人員有意識地定義每個元件的顯示方式。透過明確設定CSS屬性 display,Angular組件的顯示可以完全控制,從而實現所需的佈局和響應能力。

有用戶想要在微軟商店尋找自己喜歡的應用程式並下載安裝,但是發現微軟商店打不開了,同時還提示"很抱歉!出錯了,但我們做對了",那麼我們應該如何解決,才能讓微軟商店恢復正常運作並使用呢?下面小編整理了兩種方法,希望可以很好的幫助你!方法一可以按Win+R→輸入cmd然後按住ctrl+shift→點選確定(彈出UAC後點選是)然後彈出cmd視窗(管理員模式)然後複製貼上以下內容:netshwinsockresetnetshintipresetipconfig/releaseipconfig/renewi

Vue.js適合中小型項目和快速迭代,React適用於大型複雜應用。 1)Vue.js易於上手,適用於團隊經驗不足或項目規模較小的情況。 2)React的生態系統更豐富,適合有高性能需求和復雜功能需求的項目。

UniApp是一款基於Vue.js的跨平台開發框架,可同時在多個平台上進行應用程式開發。然而,就像其他開發工具一樣,使用UniApp流程也可能會遇到一些問題和錯誤。其中一個常見的問題是組件引入失敗的報錯。本文將介紹一些解決這個問題的方法。第一步,檢查程式碼中的拼字錯誤。在UniApp中,元件的引入是透過在頁面或元件中使用import語句來實現的。當出現組件引入
