React Hooks
面试官:说说对React Hooks的理解?解决了什么问题?

一、是什�?
Hook �?React 16.8 的新增特性。它可以让你在不编写 class 的情况下使用 state 以及其他�?React 特�?
至于为什么引入hook,官方给出的动机是解决长时间使用和维护react过程中常遇到的问题,例如�?
- 难以重用和共享组件中的与状态相关的逻辑
- 逻辑复杂的组件难以开发与维护,当我们的组件需要处理多个互不相关的 local state 时,每个生命周期函数中可能会包含着各种互不相关的逻辑在里�?- 类组件中的this增加学习成本,类组件在基于现有工具的优化上存在些许问�?- 由于业务变动,函数组件不得不改为类组件等�?
在以前,函数组件也被称为无状态的组件,只负责渲染的一些工�?
因此,现在的函数组件也可以是有状态的组件,内部也可以维护自身的状态以及做一些逻辑方面的处�?
二、有哪些
上面讲到,Hooks让我们的函数组件拥有了类组件的特性,例如组件内的状态、生命周�?
最常见的hooks有如下:
- useState
- useEffect
- 其他
useState
首先给出一个例子,如下�?
1 | import React, { useState } from 'react'; |
在函数组件中通过useState实现函数内部维护state,参数为state默认的值,返回值是一个数组,第一个值为当前的state,第二个值为更新state的函�?
该函数组件等价于的类组件如下�?
1 | class Example extends React.Component { |
从上述两种代码分析,可以看出两者区别:
- state声明方式:在函数组件中通过 useState 直接获取,类组件通过constructor 构造函数中设置
- state读取方式:在函数组件中直接使用变量,类组件通过
this.state.count的方式获�? - state更新方式:在函数组件中通过 setCount 更新,类组件通过this.setState()
总的来讲,useState 使用起来更为简洁,减少了this指向不明确的情况
useEffect
useEffect可以让我们在函数组件中进行一些带有副作用的操�?
同样给出一个计时器示例�?
1 | class Example extends React.Component { |
从上面可以看见,组件在加载和更新阶段都执行同样操�?
而如果使用useEffect后,则能够将相同的逻辑抽离出来,这是类组件不具备的方法
对应的useEffect示例如下�?
1 | import React, { useState, useEffect } from 'react'; |
useEffect第一个参数接受一个回调函数,默认情况下,useEffect会在第一次渲染和更新之后都会执行,相当于在componentDidMount和componentDidUpdate两个生命周期函数中执行回�?
如果某些特定值在两次重渲染之间没有发生变化,你可以跳过对 effect 的调用,这时候只需要传入第二个参数,如下:
1 | useEffect(() => { |
所以, useEffect相当于componentDidMount,componentDidUpdate �?componentWillUnmount 这三个生命周期函数的组合
其它 hooks
在组件通信过程中可以使用useContext,refs学习中我们也用到了useRef获取DOM结构……
还有很多额外的hooks,如�?
- useReducer
- useCallback
- useMemo
- useRef
三、解决什�?
通过对上面的初步认识,可以看到hooks能够更容易解决状态相关的重用的问题:
- 每调用useHook一次都会生成一份独立的状�?
- 通过自定义hook能够更好的封装我们的功能
编写hooks为函数式编程,每个功能都包裹在函数中,整体风格更清爽,更优雅
hooks的出现,使函数组件的功能得到了扩充,拥有了类组件相似的功能,在我们日常使用中,使用hooks能够解决大多数问题,并且还拥有代码复用机制,因此优先考虑hooks