react 函数 - useState , useEffect, useCallback (记忆函数), useMemo (记忆组件),useRef (保存引用值)

一.hooks - useState

import React, { useState } from "react";

export default function App() {
  // list 调用 useState
  // arrlist 修改 useState 
  const [list, arrlist] = useState(["我是useState","1111","2222"]);

  const clickusestate = () =>{
    arrlist(["我啊","555555","8888"])
  }

  return <div>
    <button onClick={clickusestate}>点击</button>
    <ul>
      {
        list.map(item =>
          <li key={item}>{item}</li>
        )
      }
    </ul>
  </div>
}

二. hooks - useEffect

import React,{useEffect,useState} from "React"
export default function App (){
	const [list,arrlist] = useState([])
	useEffect(()=>{
		axios
     },[])
     // [] 传递空数组 只会执行一次 
     // [list] 绑定参数 参数发生改变执行一次
     // [list,age] 可以绑定多个参数
	return<div>
	</div>
}

三. hooks - useCallback (记忆函数)

import React,{useState,useCallback } from "React"

export default function App(){
	const [liat,arrlist] = useState(0)
	// 防止组件重新渲染,导致方法被重新创建,起到缓存作用,只有[]中参数发生改变,才重新声明
	var clickbutton = useCallback(()=>{
		console.log(list)
		arrlist+1;
     },[list])
	return <div>
		<button onClick={()=>clickbutton()}></button>
    </div>
}

四. hooks - useMemo (记忆组件)

import React,{useMemo,useState} from "React"
export default function App(){
	const [list,arrlist] = useState([])
	// useMemo 和 useCallback 基本相同
	// useMemo 若[]参数不发生改变,只执行函数,把以前计算好的结果返回
	// 若参数发生改变则重新计算
	var clickusememo = useMemo(()=>{
		console.log(list)
		arrlist("88888")
    },[list])
	return<div>
		<button onClick={()=>clickusememo()}></button>
    </div>
}

五.hooks - useRef (保存引用值)

import React,{useState,useRef} from "React"
export default function App(){
	// 获取input
	var myref = useRef()
	var clickref = () =>{
	    console.log(myref)
	}
	return <div>
	   <input ref={myref}>
	   <button onClick={()=>clickref()}></button>
    </div>
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. useState:用于在函数组件中添加状态(state)。useState返回一个数组,包含当前状态和一个更新状态的函数。例如: ```javascript import React, { useState } from 'react'; function Counter() { const [count, setCount] = useState(0); return ( <div> <p>You clicked {count} times</p> <button onClick={() => setCount(count + 1)}> Click me </button> </div> ); } ``` 2. useEffect:用于在函数组件中添加副作用(side effect),例如订阅事件、修改 DOM 等。useEffect 接受两个参数,第一个参数是一个函数,用于执行副作用操作,第二个参数是一个数组,用于指定副作用的依赖项。例如: ```javascript import React, { useState, useEffect } from 'react'; function Example() { const [count, setCount] = useState(0); useEffect(() => { document.title = `You clicked ${count} times`; }, [count]); return ( <div> <p>You clicked {count} times</p> <button onClick={() => setCount(count + 1)}> Click me </button> </div> ); } ``` 3. useCallback:用于缓存函数,避免不必要的重新渲染。useCallback 接受两个参数,第一个参数是需要缓存的函数,第二个参数是一个依赖数组。例如: ```javascript import React, { useState, useCallback } from 'react'; function Example() { const [count, setCount] = useState(0); const handleClick = useCallback(() => { setCount(count + 1); }, [count]); return ( <div> <p>You clicked {count} times</p> <button onClick={handleClick}> Click me </button> </div> ); } ``` 4. useMemo:用于缓存计算结果,避免重复计算。useMemo 接受两个参数,第一个参数是需要缓存的函数,第二个参数是一个依赖数组。例如: ```javascript import React, { useState, useMemo } from 'react'; function Example() { const [count, setCount] = useState(0); const result = useMemo(() => { return count * 2; }, [count]); return ( <div> <p>You clicked {count} times</p> <p>The result is {result}</p> <button onClick={() => setCount(count + 1)}> Click me </button> </div> ); } ``` 5. useRef:用于在函数组件中创建一个可变的引用reference)。useRef 返回一个包含引用的对象。例如: ```javascript import React, { useState, useRef } from 'react'; function Example() { const [count, setCount] = useState(0); const timerRef = useRef(null); const handleClick = () => { timerRef.current = setInterval(() => { setCount(count => count + 1); }, 1000); }; const handleStopClick = () => { clearInterval(timerRef.current); }; return ( <div> <p>You clicked {count} times</p> <button onClick={handleClick}> Start </button> <button onClick={handleStopClick}> Stop </button> </div> ); } ``` 6. useContext:用于在函数组件中访问上下文(context)。useContext 接受一个上下文对象(由 React.createContext 创建),并返回当前上下文的。例如: ```javascript import React, { useContext } from 'react'; const ThemeContext = React.createContext('light'); function Example() { const theme = useContext(ThemeContext); return ( <div> <p>Current theme is: {theme}</p> </div> ); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值