React中的ref屬性的使用示例詳解
ref 簡(jiǎn)介
React提供的這個(gè)ref屬性,表示為對(duì)組件真正實(shí)例的引用,其實(shí)就是ReactDOM.render()返回的組件實(shí)例;需要區(qū)分一下,ReactDOM.render()渲染組件時(shí)返回的是組件實(shí)例;而渲染dom元素時(shí),返回是具體的dom節(jié)點(diǎn)。
例如,下面代碼:
const domCom = <button type="button">button</button>; const refDom = ReactDOM.render(domCom,container); //ConfirmPass的組件內(nèi)容省略 const refCom = ReactDOM.render(<ConfirmPass/>,container); console.log(refDom); console.log(refCom);
1. 字符串形式的ref
import React, { Component } from 'react'
export default class index extends Component {
showData = () => {
// 獲取input節(jié)點(diǎn)
const { inputRef } = this.refs
// 輸出input值
console.log(inputRef.value);
}
render() {
return (
<div>
<input ref="inputRef" type="text" placeholder="點(diǎn)擊按鈕提示數(shù)據(jù)"/>
<button onClick={ this.showData }>點(diǎn)我提示輸入框值</button>
</div>
)
}
}2. create形式的ref
import React, { Component } from 'react'
export default class index extends Component {
// React.createRef調(diào)用后返回一個(gè)容器,存儲(chǔ)被ref標(biāo)識(shí)的節(jié)點(diǎn),單一使用。也就是說,沒定義一個(gè)ref就要調(diào)用一次React.createRef
inputRef = React.createRef()
showData = () => {
const refVal = this.inputRef.current
console.log(refVal.value);
}
render() {
return (
<div>
<input ref={ this.inputRef } type="text" placeholder="點(diǎn)擊按鈕提示數(shù)據(jù)"/>
<button onClick={ this.showData }>點(diǎn)我提示輸入框值</button>
</div>
)
}
}3. 回調(diào)函數(shù)形式的ref
import React, { Component } from 'react'
export default class index extends Component {
showData = () => {
const { inputRef } = this
console.log(inputRef.value);
}
render() {
return (
<div>
{/* 這里傳入一個(gè)回調(diào)函數(shù) */}
<input ref={ currentNode => this.inputRef = currentNode } type="text" placeholder="點(diǎn)擊按鈕提示數(shù)據(jù)"/>
<button onClick={ this.showData }>點(diǎn)我提示輸入框值</button>
</div>
)
}
}總結(jié):
綜合以上三種形式各有優(yōu)缺點(diǎn),方式1與方式2寫起來比較方便但是比較繁瑣,方式三通過傳入一個(gè)回調(diào)函數(shù),不但簡(jiǎn)化了操作還不失優(yōu)雅,顯得代碼逼格高些,但在最新版及以后的版本中,React官方使用函數(shù)式編程,所以更推薦使用create形式的ref。
到此這篇關(guān)于React中的ref屬性的使用的文章就介紹到這了,更多相關(guān)React ref屬性使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react性能優(yōu)化useMemo與useCallback使用對(duì)比詳解
這篇文章主要為大家介紹了react性能優(yōu)化useMemo與useCallback使用對(duì)比詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
從零開始搭建webpack+react開發(fā)環(huán)境的詳細(xì)步驟
這篇文章主要介紹了從零開始搭建webpack+react開發(fā)環(huán)境的詳細(xì)步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05
基于React和antd實(shí)現(xiàn)自定義進(jìn)度條的示例代碼
在現(xiàn)代 Web 開發(fā)中,進(jìn)度條是一種常見且實(shí)用的 UI 組件,用于直觀地向用戶展示任務(wù)的完成進(jìn)度,本文將詳細(xì)介紹如何使用 React 來構(gòu)建一個(gè)自定義的進(jìn)度條,它不僅能夠動(dòng)態(tài)展示進(jìn)度,還具備額外的信息提示功能,需要的朋友可以參考下2025-03-03
react項(xiàng)目如何運(yùn)行在微信公眾號(hào)
這篇文章主要介紹了react項(xiàng)目如何運(yùn)行在微信公眾號(hào),幫助大家更好的理解和學(xué)習(xí)使用react,感興趣的朋友可以了解下2021-04-04
ReactiveCocoa代碼實(shí)踐之-UI組件的RAC信號(hào)操作
這篇文章主要介紹了ReactiveCocoa代碼實(shí)踐之-UI組件的RAC信號(hào)操作 的相關(guān)資料,需要的朋友可以參考下2016-04-04

