React報(bào)錯Function?components?cannot?have?string?refs
總覽
當(dāng)我們在一個(gè)函數(shù)組件中使用一個(gè)字符串作為ref時(shí),會產(chǎn)生"Function components cannot have string refs"錯誤。為了解決該錯誤,使用useRef()鉤子來得到一個(gè)可變的ref對象,這樣你就可以在組件中作為ref使用。

這里有個(gè)示例用來展示錯誤是如何發(fā)生的。
// App.js
export default function App() {
// A string ref has been found within a strict mode tree.
// ?? Function components cannot have string refs.
// We recommend using useRef() instead.
return (
<div>
<input type="text" id="message" ref="msg" />
</div>
);
}
上述代碼片段的問題在于,我們使用了字符串作為ref。
useRef
為了解決該錯誤,使用useRef鉤子來獲取可變的ref對象。
// App.js
import {useEffect, useRef} from 'react';
export default function App() {
const refContainer = useRef(null);
useEffect(() => {
// ??? this is reference to input element
console.log(refContainer.current);
refContainer.current.focus();
}, []);
return (
<div>
<input type="text" id="message" ref={refContainer} />
</div>
);
}
useRef()鉤子可以被傳遞一個(gè)初始值作為參數(shù)。該鉤子返回一個(gè)可變的ref對象,其.current屬性被初始化為傳遞的參數(shù)。
需要注意的是,我們必須訪問ref對象上的current屬性,以獲得對我們設(shè)置了ref屬性的input元素的訪問。
當(dāng)我們傳遞ref屬性到元素上時(shí),比如說,<input ref={myRef} /> 。React將ref對象上的.current屬性設(shè)置為相應(yīng)的DOM節(jié)點(diǎn)。
useRef鉤子創(chuàng)建了一個(gè)普通的JavaScript對象,但在每次渲染時(shí)都給你相同的ref對象。換句話說,它幾乎是一個(gè)帶有.current屬性的記憶化對象值。
不會重新渲染
應(yīng)該注意的是,當(dāng)你改變ref的current屬性的值時(shí),不會引起重新渲染。
例如,一個(gè)ref不需要包含在useEffect鉤子的依賴數(shù)組中,因?yàn)楦淖兯?code>current屬性不會引起重新渲染。
// App.js
import {useEffect, useRef} from 'react';
export default function App() {
const refContainer = useRef(null);
const refCounter = useRef(0);
useEffect(() => {
// ??? this is reference to input element
console.log(refContainer.current);
refContainer.current.focus();
// ??? incrementing ref value does not cause re-render
refCounter.current += 1;
console.log(refCounter.current);
}, []);
return (
<div>
<input type="text" id="message" ref={refContainer} />
</div>
);
}
例子中的useEffect鉤子只運(yùn)行了2次,因?yàn)?code>useRef在其內(nèi)容發(fā)生變化時(shí)并沒有通知我們。
改變對象的current屬性并不會導(dǎo)致重新渲染。
以上就是React報(bào)錯Function components cannot have string refs的詳細(xì)內(nèi)容,更多關(guān)于React報(bào)錯Function components cannot have string refs的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
react純函數(shù)組件setState更新頁面不刷新的解決
在開發(fā)過程中,經(jīng)常遇到組件數(shù)據(jù)無法更新,本文主要介紹了react純函數(shù)組件setState更新頁面不刷新的解決,感興趣的可以了解一下2021-06-06
完美解決react-codemirror2?編輯器需點(diǎn)擊一下或者延時(shí)才顯示數(shù)據(jù)的問題
這篇文章主要介紹了react-codemirror2編輯器需點(diǎn)擊一下或者延時(shí)才顯示數(shù)據(jù)的問題,解決方法也很簡單,需要手動引入自動刷新的插件,配置一下參數(shù)就可以了,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08
關(guān)于react hook useState連續(xù)更新對象的問題
這篇文章主要介紹了關(guān)于react hook useState連續(xù)更新對象的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
React引入css的幾種方式及應(yīng)用小結(jié)
這篇文章主要介紹了React引入css的幾種方式及應(yīng)用小結(jié),操作styled組件的樣式屬性,可在組件標(biāo)簽上定義屬性、也可以通過attrs定義屬性,本文通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03
React+Typescript創(chuàng)建項(xiàng)目的實(shí)現(xiàn)步驟
通過React組件庫和TypeScript的強(qiáng)類型特性,開發(fā)者可以創(chuàng)建出具有優(yōu)秀用戶體驗(yàn)和穩(wěn)定性的Web應(yīng)用程序,本文主要介紹了React+Typescript創(chuàng)建項(xiàng)目的實(shí)現(xiàn)步驟,感興趣的可以了解一下2023-08-08

