首頁 web前端 js教程 使用store來優化React元件

使用store來優化React元件

Jan 04, 2018 am 10:03 AM
react store 組件

本文主要介紹了使用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

Ecstore取得dbschema內容?

淺談react 同構之樣式直出

以上是使用store來優化React元件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

熱門話題

Java教學
1663
14
CakePHP 教程
1419
52
Laravel 教程
1313
25
PHP教程
1263
29
C# 教程
1237
24
如何安裝Win10舊版元件DirectPlay 如何安裝Win10舊版元件DirectPlay Dec 28, 2023 pm 03:43 PM

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

PHP、Vue和React:如何選擇最適合的前端框架? PHP、Vue和React:如何選擇最適合的前端框架? Mar 15, 2024 pm 05:48 PM

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

如何開啟win10舊版組件的設置 如何開啟win10舊版組件的設置 Dec 22, 2023 am 08:45 AM

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

Java框架與前端React框架的整合 Java框架與前端React框架的整合 Jun 01, 2024 pm 03:16 PM

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

Angular元件及其顯示屬性:了解非block預設值 Angular元件及其顯示屬性:了解非block預設值 Mar 15, 2024 pm 04:51 PM

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

微軟商店打不開顯示\'很抱歉!出錯了,但我們做對了\'-【詳細解決方法】 微軟商店打不開顯示\'很抱歉!出錯了,但我們做對了\'-【詳細解決方法】 Mar 27, 2024 pm 01:21 PM

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

vue.js vs.反應:特定於項目的考慮因素 vue.js vs.反應:特定於項目的考慮因素 Apr 09, 2025 am 12:01 AM

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

UniApp報錯:'xxx'元件引入失敗的解決辦法 UniApp報錯:'xxx'元件引入失敗的解決辦法 Nov 25, 2023 pm 12:58 PM

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

See all articles