真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用store來優(yōu)化React組件的方法-創(chuàng)新互聯(lián)

在使用 React 編寫組件的時候,我們常常會碰到兩個不同的組件之間需要共享狀態(tài)情況,而通常的做法就是提升狀態(tài)到父組件。但是這樣做會有一個問題,就是盡管只有兩個組件需要這個狀態(tài),但是因?yàn)榘褷顟B(tài)提到了父組件,那么在狀態(tài)變化的時候,父組件以及其下面的所有子組件都會重新 render,如果你的父組件比較復(fù)雜,包含了其他很多子組件的話,就有可能引起性能問題。

創(chuàng)新互聯(lián)是一家專業(yè)提供尼瀘西企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為尼瀘西眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進(jìn)行中。

Redux 通過把狀態(tài)放在全局的 store 里,然后組件去訂閱各自需要的狀態(tài),當(dāng)狀態(tài)發(fā)生變化的時候,只有那些訂閱的狀態(tài)發(fā)生變化的組件才重新 render,這樣就避免了上面說的提升狀態(tài)所帶來的副作用。但是,當(dāng)我們在寫一個 React 組件庫的時候,redux 加 react-redux 的組合可能就有點(diǎn)太重了。所以我們可以自己寫一個簡單的 store,來實(shí)現(xiàn)類似 Redux 的訂閱模式。

參考 Redux 的實(shí)現(xiàn)來寫一個簡版的 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,
 };
}

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


文章標(biāo)題:使用store來優(yōu)化React組件的方法-創(chuàng)新互聯(lián)
當(dāng)前網(wǎng)址:http://weahome.cn/article/doejgd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部