亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解React中共享組件邏輯的三種方式

 更新時(shí)間:2021年02月02日 16:46:53   作者:Null2020  
這篇文章主要介紹了詳解React中共享組件邏輯的三種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

廢話少說(shuō),這三種方式分別是:render props、高階組件和自定義Hook。下面依次演示

假設(shè)有一個(gè)TimeOnPage組件專門用來(lái)記錄用戶在當(dāng)前頁(yè)面停留時(shí)間,像這樣:

const TimeOnPage = () => {
 const [second, setSecond] = useState(0);

 useEffect(() => {
  setTimeout(() => {
   setSecond(second + 1);
  }, 1000);
 }, [second]);
 return (
  <div>停留時(shí)間:{second}秒</div>
 );
}

如果另一個(gè)組件需要復(fù)用這個(gè)功能,我們能否封裝一下,以便輕松地與其它組件共享?

一般很自然地想到子組件嵌套的方式,利用props傳參

const Child = (props) => {
 return <div>stayTime: {props.stayTime}s</div>;
};

const TimeOnPage = () => {
 const [second, setSecond] = useState(0);

 useEffect(() => {
  setTimeout(() => {
   setSecond(second + 1);
  }, 1000);
 }, [second]);
 return (
  <div>
   <Child stayTime={second} />
  </div>
 );
}

這屬于在 TimeOnPage組件內(nèi)部硬編碼,還沒(méi)有達(dá)到封裝復(fù)用的目標(biāo)??纯磖ender props怎么做?

render props

“render prop” 是指一種在 React 組件之間使用一個(gè)值為函數(shù)的 prop 共享代碼的簡(jiǎn)單技術(shù)

接上文,在TimeOnPage里定義一個(gè)值為函數(shù)的prop,想渲染什么組件,在函數(shù)里返回即可,函數(shù)的參數(shù)就是想要共享的state。

const Child = (props) => {
 return <div>stayTime: {props.stayTime}s</div>;
};

const TimeOnPage = (props) => {
 const [second, setSecond] = useState(0);

 useEffect(() => {
  setTimeout(() => {
   setSecond(second + 1);
  }, 1000);
 }, [second]);
 return <div>{props.render(second)}</div>;
};

<TimeOnPage render={(stayTime) => <Child stayTime={stayTime} />

其實(shí),render prop 就是一個(gè)用于告知組件需要渲染什么內(nèi)容的函數(shù)prop。
React Router也用到了這項(xiàng)技術(shù)。

<Router>
 <Route path="/home" render={() => <div>Home</div>} />
</Router>

高階組件

高階組件(HOC)是 React 中用于復(fù)用組件邏輯的一種高級(jí)技巧。HOC 自身不是 React API 的一部分,它是一種基于 React 的組合特性而形成的設(shè)計(jì)模式。

高階組件是一個(gè)函數(shù),參數(shù)是一個(gè)需要被復(fù)用的組件A,返回值是一個(gè)新的組件N。新組件N是在組件A的基礎(chǔ)上做了一些加工,但不會(huì)修改組件A本身,只是功能增強(qiáng)。

假設(shè)有一個(gè)新聞列表組件長(zhǎng)這樣:

const NewList = () => {
 return (
  <div>
   <ul>
    <li>news item</li>
    <li>news item</li>
   </ul>
  </div>
 );
}

想要在新聞列表加載期間顯示loading動(dòng)畫(huà)組件 <Loading />,通常會(huì)這么做

const Loading = () => {
 // loading動(dòng)畫(huà)
}
const NewList = ({ isLoading }) => {
 return isLoading ? (
  <Loading />
 ) : (
  <div>
   <ul>
    <li>news item</li>
    <li>news item</li>
   </ul>
  </div>
 );
};

假設(shè)現(xiàn)在Table組件也要在加載數(shù)據(jù)期間顯示loading動(dòng)畫(huà)組件,遵循類似的模式

const Loading = () => {
 // loading動(dòng)畫(huà)
}
const DataList = ({ isLoading, ...props }) => {
 return isLoading ? (
  <Loading />
 ) : (
  <Table {...props} />
 );
};

以上,你會(huì)發(fā)現(xiàn)DataList和NewList結(jié)構(gòu)極度相似,如果還有第三個(gè)、第四個(gè)組件要加loading,繼續(xù)照這個(gè)模式重復(fù)第三次、第四次嗎?這不是最理想的做法,更好的做法是,使用高階組件把這個(gè)模式抽象出來(lái):

const WithLoading = (WrappedComponent) => {
 return ({isLoading, ...props}) => {
  return isLoading ? <Loading /> : <WrappedComponent {...props} />;
 }
};

然后就可以在不修改NewList和DataList的情況下分別給他們?cè)黾觢oading

const NewList = () => {
 return (
  <div>
   <ul>
    <li>news item</li>
    <li>news item</li>
   </ul>
  </div>
 );
};

const DataList = (props) => {
 return <Table {...props} />
};

const WithLoading = (WrappedComponent) => {
 return ({isLoading, ...props}) => {
  return isLoading ? <Loading /> : <WrappedComponent {...props} />;
 }
};
// 帶loading的NewList
const WithLoadingNewList = WithLoading(<NewList />)
// 帶loading的DataList
const WithLoadingDataList = WithLoading(<DataList />)

自定義Hook

Hook 是 React 16.8 的新增特性。它可以讓你在不編寫(xiě) class 的情況下使用 state 以及其他的 React 特性。

React Hook有useState、useEffect等,它們都是函數(shù),自定義Hook也是一個(gè)函數(shù),它的名稱同樣以u(píng)se開(kāi)頭,函數(shù)內(nèi)部可以調(diào)用其它Hook。與React組件不同的是,自定義Hook可以沒(méi)有返回值。與普通函數(shù)不同的是,自定義Hook內(nèi)部可以調(diào)用其它Hook,而普通函數(shù)則不行。

在寫(xiě)業(yè)務(wù)邏輯過(guò)程中,一般會(huì)將一些可重用的的方法定義成工具函數(shù),然后就可以到處復(fù)用。同樣,通過(guò)自定義 Hook,可以將組件邏輯提取到可重用的函數(shù)中。到底選擇自定義Hook還是工具函數(shù),取決于要提取的組件邏輯需不需要用到其他Hook,如果需要,就選擇自定義Hook,否則用工具函數(shù)即可。

回到本文第一個(gè) TimeOnPage組件,改成自定義Hook的形式

const useTimeOnPage = () => {
 const [second, setSecond] = useState(0);

 useEffect(() => {
  setTimeout(() => {
   setSecond(second + 1);
  }, 1000);
 }, [second]);
 return second;
}

使用方法

const Demo = () => {
 const stayTime = useTimeOnPage();
 return <div>當(dāng)前頁(yè)面停留時(shí)間:{stayTime}秒</div>
}

總結(jié)

三種共享組件邏輯的方式有各自的適用場(chǎng)景:
render props適合共享那些有不同子組件/子元素的父組件,子組件/子元素的“坑位”已經(jīng)定義好了,只能渲染在指定位置;
高階組件適合在不修改原有組件的基礎(chǔ)上對(duì)組件進(jìn)行擴(kuò)展;
自定義Hook能做的,純函數(shù)基本上也能做,只是有時(shí)候用自定義Hook實(shí)現(xiàn)會(huì)更方便快捷。
本文鏈接:Github

 到此這篇關(guān)于詳解React中共享組件邏輯的三種方式的文章就介紹到這了,更多相關(guān)React 共享組件邏輯內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用reactjs優(yōu)化了進(jìn)度條頁(yè)面性能提高70%

    使用reactjs優(yōu)化了進(jìn)度條頁(yè)面性能提高70%

    這篇文章主要介紹了使用reactjs優(yōu)化了進(jìn)度條后頁(yè)面性能提高了70%的操作技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • React使用Context與router實(shí)現(xiàn)權(quán)限路由詳細(xì)介紹

    React使用Context與router實(shí)現(xiàn)權(quán)限路由詳細(xì)介紹

    這篇文章主要介紹了React使用Context與router實(shí)現(xiàn)權(quán)限路由的詳細(xì)過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2023-01-01
  • React Native實(shí)現(xiàn)地址挑選器功能

    React Native實(shí)現(xiàn)地址挑選器功能

    這篇文章主要為大家詳細(xì)介紹了React Native仿地址挑選器功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • react antd-mobile ActionSheet+tag實(shí)現(xiàn)多選方式

    react antd-mobile ActionSheet+tag實(shí)現(xiàn)多選方式

    這篇文章主要介紹了react antd-mobile ActionSheet+tag實(shí)現(xiàn)多選方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • React通過(guò)父組件傳遞類名給子組件的實(shí)現(xiàn)方法

    React通過(guò)父組件傳遞類名給子組件的實(shí)現(xiàn)方法

    React 是一個(gè)用于構(gòu)建用戶界面的 JAVASCRIPT 庫(kù)。這篇文章主要介紹了React通過(guò)父組件傳遞類名給子組件的方法,需要的朋友可以參考下
    2017-11-11
  • 如何深入理解React的ref 屬性

    如何深入理解React的ref 屬性

    關(guān)于 Refs ,React 官網(wǎng)講解的對(duì)于新手來(lái)說(shuō)不太友好,還是自己一字一句解讀后并以代碼驗(yàn)證的方式后真正理解的.
    2021-05-05
  • 解決React報(bào)錯(cuò)JSX?element?type?does?not?have?any?construct?or?call?signatures

    解決React報(bào)錯(cuò)JSX?element?type?does?not?have?any?construct

    這篇文章主要為大家介紹了解決React報(bào)錯(cuò)JSX?element?type?does?not?have?any?construct?or?call?signatures,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • React?中使用?Redux?的?4?種寫(xiě)法小結(jié)

    React?中使用?Redux?的?4?種寫(xiě)法小結(jié)

    這篇文章主要介紹了在?React?中使用?Redux?的?4?種寫(xiě)法,Redux 一般來(lái)說(shuō)并不是必須的,只有在項(xiàng)目比較復(fù)雜的時(shí)候,比如多個(gè)分散在不同地方的組件使用同一個(gè)狀態(tài),本文就React使用?Redux的相關(guān)知識(shí)給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2022-06-06
  • react map使用方法實(shí)例詳解

    react map使用方法實(shí)例詳解

    map()方法是在React中常用的數(shù)組處理方法之一,可以用于遍歷數(shù)組、生成組件列表以及進(jìn)行數(shù)據(jù)轉(zhuǎn)換等操作,通過(guò)合理運(yùn)用map()方法,可以更靈活地處理和展示數(shù)據(jù),下面給大家講解react map使用方法,感興趣的朋友一起看看吧
    2023-10-10
  • 詳解關(guān)于react-redux中的connect用法介紹及原理解析

    詳解關(guān)于react-redux中的connect用法介紹及原理解析

    本篇文章主要介紹了詳解關(guān)于react-redux中的connect用法介紹及原理解析,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2017-09-09

最新評(píng)論