React为什么要搞一个Hooks

React为什么要搞一个Hooks

https://github.com/happylindz/blog/issues/19

想要复用一个有状态的组件太麻烦了!

我们都知道React的核心思想就是,将一个页面拆分成一堆独立的,可以复用的组件,并且用自上而下的单向数据流的形式将这些组件串联起来。但如果在大型的项目中使用React,那么我们就会发现项目中实际上很多React组件冗长且难以复用。尤其是那些写成class的组件,他们本身本来就包含了状态(state),所以复用这类组件就变得很麻烦。

那之前,官方解决这个问题的办法是使用渲染属性(Render Props) 和高阶组件(Highter-Order Components)

渲染属性:渲染属性指的是使用一个值为函数的prop来传递需要动态渲染的nodes或组件。如下面的代码可以看到我们的DataProvider组件包含了所有跟状态相关的代码,而Cat组件则可以是一个单纯的展示型组件,这样一来DataProvider就可以单独复用了。

高阶组件:说白了就是一个函数接受一个组件作为参数,经过一系列加工后,最后返回一个新的组件。看下面的代码示例,withUser函数就是一个高阶组件,它返回了一个新的组件,这个组件具有了它提供的获取用户信息的功能。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值