废话少说,这三种方式分别是:render props、高阶组件和自定义Hook。下面依次演示
假设有一个TimeOnPage组件专门用来记录用户在当前页面停留时间,像这样:
const TimeOnPage = () => { const [second, setSecond] = useState(0); useEffect(() => { setTimeout(() => { setSecond(second + 1); }, 1000); }, [second]); return ( <div>停留时间:{second}秒</div> ); }
如果另一个组件需要复用这个功能,我们能否封装一下,以便轻松地与其它组件共享?
一般很自然地想到子组件嵌套的方式,利用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组件内部硬编码,还没有达到封装复用的目标。看看render props怎么做?
render props
“render prop” 是指一种在 React 组件之间使用一个值为函数的 prop 共享代码的简单技术
接上文,在TimeOnPage里定义一个值为函数的prop,想渲染什么组件,在函数里返回即可,函数的参数就是想要共享的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} />
其实,render prop 就是一个用于告知组件需要渲染什么内容的函数prop。
React Router也用到了这项技术。
<Router> <Route path="/home" render={() => <div>Home</div>} /> </Router>
高阶组件
高阶组件(HOC)是 React 中用于复用组件逻辑的一种高级技巧。HOC 自身不是 React API 的一部分,它是一种基于 React 的组合特性而形成的设计模式。
高阶组件是一个函数,参数是一个需要被复用的组件A,返回值是一个新的组件N。新组件N是在组件A的基础上做了一些加工,但不会修改组件A本身,只是功能增强。
假设有一个新闻列表组件长这样:
const NewList = () => { return ( <div> <ul> <li>news item</li> <li>news item</li> </ul> </div> ); }
想要在新闻列表加载期间显示loading动画组件 <Loading />,通常会这么做
const Loading = () => { // loading动画 } const NewList = ({ isLoading }) => { return isLoading "htmlcode">const Loading = () => { // loading动画 } const DataList = ({ isLoading, ...props }) => { return isLoading "htmlcode">const WithLoading = (WrappedComponent) => { return ({isLoading, ...props}) => { return isLoading "htmlcode">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 "htmlcode">const useTimeOnPage = () => { const [second, setSecond] = useState(0); useEffect(() => { setTimeout(() => { setSecond(second + 1); }, 1000); }, [second]); return second; }使用方法
const Demo = () => { const stayTime = useTimeOnPage(); return <div>当前页面停留时间:{stayTime}秒</div> }总结
三种共享组件逻辑的方式有各自的适用场景:
render props适合共享那些有不同子组件/子元素的父组件,子组件/子元素的“坑位”已经定义好了,只能渲染在指定位置;
高阶组件适合在不修改原有组件的基础上对组件进行扩展;
自定义Hook能做的,纯函数基本上也能做,只是有时候用自定义Hook实现会更方便快捷。
本文链接:Github到此这篇关于详解React中共享组件逻辑的三种方式的文章就介绍到这了,更多相关React 共享组件逻辑内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- [天乐AA天碟]UncompressedWorldVol.1《无压缩世界1:纯净原音》[24-96]FLAC
- 陈琳.1994-请别再说爱我(TP版)【国际文化】【WAV+CUE】
- 吴倩莲.1996-回家【EMI百代】【WAV+CUE】
- 群星.1989-宝丽金浪漫舞曲超白金【宝丽金】【WAV+CUE】
- 许茹芸《高端定制音响专业示范碟 我为芸开》[WAV+CUE][600MB]
- 费翔-《献给最挑剔的耳朵 精挑细选十八首 HQCD》[WAV+CUE][650MB]
- 《邓丽君 70周年特集4CD香港版》[WAV+CUE][1.7GB]
- 减压睡眠音乐《听着音乐SPA入眠2CD》HQ金碟[DTS+WAV]
- 群星《2016最受欢迎女歌手2CD》DTS-ES[WAV分轨]
- 24Bit极品发烧人声测试《男人咖啡·HIFI男声2CD》DTS[WAV/分轨]
- 陈震.1994-不要让我再爱你再想你【蓝与白】【WAV+CUE】
- 群星.2012-赵季平创作歌曲精选4CD【上海音乐出版社】【WAV+CUE】
- 梁汉文.1998-星火【华星】【WAV+CUE】
- AhNeeMah阿尼玛《NativeSpirit原始灵魂》(2009)示范碟DTS-NRG
- 群星1992-卡拉屋企[香港首版][WAV+CUE]