美文网首页
React-Hooks之内置hooks

React-Hooks之内置hooks

作者: Guow110 | 来源:发表于2021-09-14 14:23 被阅读0次

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 来做太多数据的共享


个人学习记录,侵权可删

相关文章

  • react-hooks

    前置 学习面试视频 总结react hooks react-hooks react-hooks为函数组件提供了一些...

  • React-Hooks之内置hooks

    1.缓存回调函数(useCallback) 如果第二个参数为[ ],则回调函数只会创建一次 2.缓存计算结果(us...

  • react-hooks

    react-hooks react-hooks 是react16.8以后,react新增的钩子API,目的是增加代...

  • React-hooks API介绍

    react-hooks HOOKS hooks概念在React Conf 2018被提出来,并将在未来的版本中被...

  • react-hooks

    一、hooks是什么? Hook 就是 JavaScript 函数,但是使用它们会有两个额外的规则:只能在函数最外...

  • react-hooks

    useEffect 如果useEffect里边同时改变了state,如果没有设置依赖,有可能会导致无限循环。因为u...

  • react-hooks

    为什么hooks不能写在条件判断语句里面

  • Taro scss module 方案

    采用react-hooks方案,使用scss方案为解决classname冲突,采用module方案。 根目录创建[...

  • react hooks 批量更新优化

    无状态组件中 批量更新失效这种情况在react-hooks中也普遍存在,这种情况甚至在hooks中更加明显,因为我...

  • useState

    react-hooks 如果你熟悉 React class 的生命周期函数,你可以把 useEffect Hook...

网友评论

      本文标题:React-Hooks之内置hooks

      本文链接:https://www.haomeiwen.com/subject/zyycgltx.html