十、【react】自定义Hook函数

  1. 先自定义一个use开头的函数
  2. 在函数中添加要复用的部分
  3. 需要在外面用到的给他return回去
  4. 在要使用的地方直接解构赋值导入即可使用
import { useEffect, useState } from "react";

function useToggle(){
    const [show, setShow] = useState(true);
    const toggle = () => {
        setShow(!show);
    }
    return {show, toggle};
}

function Son(){

    useEffect(()=>{
        const timer = setInterval(()=>{
            console.log("定时器执行中...");
        },1000)
        return () => {
            console.log("useEffect清除定时器...");
            clearInterval(timer);
        }
    },[])

    return (
        <div>
            {"Son"}
        </div>
    )  
}

  

function App4(){
    const {show, toggle} = useToggle();

    return (
        <div>
            {show && <Son/>}
            <button onClick={() => toggle()}>{show? "显示" : "隐藏"}</button>
        </div>
    )
}

export default App4;

使用规则

  1. 只能在组件中或者其他自定义Hook函数中调用
  2. 只能在组件的顶层调用,不能嵌套在 if、for、其他函数中
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值