React-Hooks之内置hooks

1.缓存回调函数(useCallback)

**useCallback(fn.deps)**

import React, { useState, useCallback } from 'react';

function Counter() {
  const [count, setCount] = useState(0);
  const handleIncrement = useCallback(
    () => setCount(count + 1),
    [count], // 只有当 count 发生变化时,才会重新创建回调函数
  );
  // ...
  return <button onClick={handleIncrement}>+</button>
}

如果第二个参数为[ ],则回调函数只会创建一次

2.缓存计算结果(useMemo)

**useMemo(fn, deps)**

//...
// 使用 userMemo 缓存计算的结果
const usersToShow = useMemo(() => {
    if (!users) return null;
    return users.data.filter((user) => {
      return user.first_name.includes(searchKey));
    }
  }, [users, searchKey]);
//...

建立了一个绑定某个结果到依赖数据的关系。只有当依赖变了,这个结果才需要被重新得到

3.多次渲染间共享数据(useRef)

**const myRefContainer = useRef(initialValue);**
  • 类似于类组件的成员变量,不直接参与组件的渲染

  • 保存某个 DOM 节点的引用

    const inputEl = useRef(null);
    <input ref={inputEl} type="text" />
    

4.定义全局状态(useContext)

const value = useContext(MyContext);
const MyContext = React.createContext(initialValue);

React 的开发中,除了像 Theme、Language 等一目了然的需要全局设置的变量外,我们很少会使用 Context 来做太多数据的共享


个人学习记录,侵权可删

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 关于hook 1.1 为什么使用hook 在react类组件(class)写法中,有setState和生命周期...
    江湖yi山人阅读 5,864评论 0 3
  • 前言 本文全面介绍了React Hooks的所有API概念、用法、丰富的demo以及部分底层原理。 实际上,Rea...
    南宫__阅读 8,999评论 0 6
  • Hooks 是React的一次革命性升级,本文将对其优势和API进行比较全面的解析 为什么要有hooks 在没有h...
    smartzheng阅读 4,477评论 0 5
  • 1、什么是Hooks 在不编写 class 的情况下使用 state 以及其他的 React 特性(生命周期) 规...
    郭仙人不是闲人阅读 3,255评论 0 0
  • React16.8 发布已经很长世间, 这段时间项目不忙, 正好准备使用 React Hooks 进行重构升级。R...
    ZiTong阅读 1,787评论 0 0