useState 是一个内置的 React hook,它允许您将信息作为状态存储在变量中。它允许您将 React 状态添加到功能组件。在下面的示例中,useState()声明状态变量,而值存储在计数变量中。setCount是用于更新此值的函数。
//从 react 导入 useState
import React, { useState } from 'react';
function Count() {
// 声明一个名为 count 的新状态变量
const [count, setCount] = useState(0);
useRef hook 是一个内置的 React hook,它将一个参数或参数作为其初始值,并返回一个引用或持久化的可变值。此引用,或简称 ref,包含可以使用当前属性检索的值。
我们还可以将用户输入存储在 refs 中并显示收集到的数据,如下所示:
//导入 useRef hook
import React, { useRef } from "react"
export default function App() {
//创建一个变量来存储引用
const nameRef = useRef();
function handleSubmit(e) {
//防止页面在提交时重新加载
e.preventDefault()
//输出 name
console.log(nameRef.current.value)
}
return (
<div className="container">
<form onSubmit={handleSubmit}>
<div className="input_group">
<label>Name</label>
<input type="text" ref={nameRef}/>
</div>
<input type="submit"/>
</form>
</div>
)
}
useState 返回 2 个属性或一个数组。一个是值或状态,另一个是更新状态的函数。相比之下, useRef 只返回一个值,即实际存储的数据。useState 中,组件必须再次渲染以更新状态或其值。refs 在获取用户输入、DOM 元素属性和存储不断更新的值时很有用。 但是,如果您要存储组件相关信息或在组件中使用方法,states 则是最佳选择。
所以总而言之,这两种 hook 各有优缺点,会根据情况和用途来使用。