JavaScript中的useRef 和 useState介紹
1、useState hook
useState 是一個內置的 React hook,它允許您將信息作為狀態(tài)存儲在變量中。它允許您將 React 狀態(tài)添加到功能組件。在下面的示例中,useState()聲明狀態(tài)變量,而值存儲在計數變量中。setCount是用于更新此值的函數。
//從 react 導入 useState
import React, { useState } from 'react';
function Count() {
// 聲明一個名為 count 的新狀態(tài)變量
const [count, setCount] = useState(0);
2、useRef hook
useRef hook 是一個內置的 React hook,它將一個參數或參數作為其初始值,并返回一個引用或持久化的可變值。此引用,或簡稱 ref,包含可以使用當前屬性檢索的值。
我們還可以將用戶輸入存儲在 refs 中并顯示收集到的數據,如下所示:
//導入 useRef hook
import React, { useRef } from "react"
export default function App() {
//創(chuàng)建一個變量來存儲引用
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>
)
}
3、useRef 與 useState
- 與狀態(tài)不同,存儲在引用或引用中的數據或值保持不變,即使在組件重新渲染之后也是如此。因此,引用不會影響組件渲染,但狀態(tài)會影響。
useState返回 2 個屬性或一個數組。一個是值或狀態(tài),另一個是更新狀態(tài)的函數。相比之下,useRef只返回一個值,即實際存儲的數據。- 當參考值發(fā)生變化時,無需刷新或重新渲染即可更新。但是在
useState中,組件必須再次渲染以更新狀態(tài)或其值。
4、何時使用 Refs 和 States
refs 在獲取用戶輸入、DOM 元素屬性和存儲不斷更新的值時很有用。 但是,如果您要存儲組件相關信息或在組件中使用方法,states 則是最佳選擇。
所以總而言之,這兩種 hook 各有優(yōu)缺點,會根據情況和用途來使用。
到此這篇關于 JavaScript中的useRef 和 useState介紹的文章就介紹到這了,更多相關 JavaScript中的useRef 和 useState內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

