本教程操作环境:Windows7系统、react17.0.1版、Dell G3电脑。
Hook是React 16.8新增的特性,专门用在函数式组件,它可以代替class组件中react的其他特性,是实际工作中要常用到的。
什么是 Hooks
Hooks 译为钩子,Hooks 就是在函数组件内,负责钩进外部功能的函数。
React 提供了一些常用钩子,React 也支持自定义钩子,这些钩子都是用于为函数引入外部功能。
当我们在组件中,需要引入外部功能时,就可以使用 React 提供的钩子,或者自定义钩子。
比如在组件内引入可管理 state 的功能,就可以使用 useState 函数,下文会详细介绍 useState 的用法。
为什么要用 Hooks(使用hook的好处)
使用 Hooks 有 2 大原因:
简化逻辑复用;
让复杂组件更易理解。
1. 简化逻辑复用,能更容易复用代码
在 Hooks 出现之前,React 必须借用高阶组件、render props 等复杂的设计模式才能实现逻辑的复用,但是高阶组件会产生冗余的组件节点,让调试更加复杂。
Hooks 让我们可以在无需修改组件结构的情况下复用状态逻辑。
举个例子,经常使用的antd-table,用的时候经常需要维护一些状态 ,并在合适的时机去更改它们:
componentDidMount(){ this.loadData();}loadData = ()=>{ this.setState({ current: xxx, total: xxx, pageSize: xxx, dataSource: xxx[] })}onTableChange = ()=>{ this.setState({ current: xxx, total: xxx, pageSize: xxx, })}render(){ const {total,pageSize,current,dataSource} = this.state; return
每个table都要写一些这种逻辑,那还有啥时间去摸鱼。这些高度类似的逻辑,可以通过封装一个高阶组件来抽象它们。这个高阶组件自带这些状态,并可以自动调用server去获取remote data。
用高阶组件来实现的话会是这样:
import { Table } from "antd"import server from "./api"function useTable(server) { return function (WrappedComponent) { return class HighComponent extends React.Component { state = { tableProps: xxx, }; render() { const { tableProps } = this.state; return; } }; };}@useTable(server)class App extends Component{ render(){ const { tableProps } = this.props; return (
如果用hooks来实现的话,会是:
import { Table } from "antd"import server from "./api"function useTable(server) { const [tableProps, setTableProps] = useState(xxx); return tableProps;}function App { const { tableProps } = useTable(); return (
相对比高阶组件“祖父=>父=>子”的层层嵌套,
hooks是这样的:
const { brother1 } = usehook1; const { brother2} = usehook2;*/
可以看到,hooks的逻辑更清晰,可读性更好。
2. 让复杂组件更易理解
在 class 组件中,同一个业务逻辑的代码分散在组件的不同生命周期函数中,而 Hooks 能够让针对同一个业务逻辑的代码聚合在一块,让业务逻辑清晰地隔离开,让代码更加容易理解和维护。
【相关推荐:Redis视频教程】
以上就是react中使用hook的好处是什么的详细内容,更多请关注php中文网其它相关文章!