react hooks

react hooks (内置的钩子)

什么是 hooks?

增强了函数组件的功能。

在没有 hooks 时,函数组件是没有状态、生命周期、ref 等。通过 hooks 使函数组件也具有这些能力。

在没有 hooks 时,函数组件是缺少部分功能的,只有 class 类组件才拥有这些功能。因此函数组件性能更优,更符合 React 的设计,所以要尽可能的用函数组件。

useState

用于定义响应式变量,和改变变量的方式,可以在数据更新时更新页面。

只要 state 发生变化,函数组件会重新渲染。而且会递归的渲染子组件,也会重新渲染。

jsx 复制代码
import { useState } from 'react';

function Example() {
    const [count, setCount] = useState(0);
    const increment = () => {
        setCount(count => count+1)
    }
    return <>
        <h1>{count}</h1>
        <button onClick={increment}>
            +
        </button>
        <button onClick={() => {setCount(666)}}>
            set count = 666
        </button>
    </>
}

useMemo

核心是缓存计算值,对于多次重复使用计算值的情况,对应用进行性能优化。

针对那些特别昂贵的计算。

如果依赖数组传入空数组,函数只调用一次。也就是只会计算一次结果,之后的值都来自缓存。

jsx 复制代码
import React, { useMemo } from 'react';
        
function MyComponent({ a, b }) {
  const expensive = useMemo(() => {
    let sum = 0;
    for (let i = 0; i < a; i++) {
      sum += 1;
      console.log(sum);
    }
    return [sum];
  }, [a]);              
  console.log("组件渲染完成!");
  return <h1>{expensive}</h1>;
}       

useEffect

用于处理组件中的副作用(如数据获取、订阅、手动修改 DOM 等)

相关推荐
2601_949593658 分钟前
基础入门 React Native 鸿蒙跨平台开发:模拟智能音响
react native·react.js·harmonyos
xiaoqi92240 分钟前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233221 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88213 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1363 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠3 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
2601_949833393 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
珑墨3 小时前
【Turbo】使用介绍
前端
军军君014 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi9225 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos