在React元件中refs的使用方法
這篇文章主要介紹了React元件refs的使用詳解,現在分享給大家,也給大家做個參考。
ref顧名思義我們知道,其實它就可以被看座是一個元件的參考,也可以說是一個標識。作為組件的屬性,其屬性值可以是字串也可以是函數。
其實,ref的使用不是必須的。即使在其適用的場景中也不是非用不可的,因為使用ref實現的功能同樣可以轉化成其他的方法來實現。但是,既然ref有其適用的場景,也就是說ref自有其優勢。關於這一點和ref的適用場景,官方文件中是這樣說的:
在從render 方法中返回UI 結構之後,你可能想衝出React 虛擬DOM 的限制,在render 返回的元件實例上呼叫某些方法。通常來說,這樣做對於應用程式中的資料流是不必要的,因為活躍的資料( Reactive data )流總是確保最新的 props 被傳遞到每一個從 render() 輸出的子級中去。然而,仍然有幾個場景使用這種方式是必須的,或者說是有益的:尋找渲染出的元件的DOM標記(可以認為是DOM的識別ID),在一個大型的非React應用中使用React元件或者是將你現有的程式碼轉換成React。
下面我們來看這樣的一個場景(下面的例子經常被用於ref的講解,可見下面描述的場景應該是比較經典的):透過某個事件使元素的值設為空字串,然後使該元素獲得焦點。
var App = React.createClass({ getInitialState: function() { return {userInput: ''}; }, handleChange: function(e) { this.setState({userInput: e.target.value}); }, clearAndFocusInput: function() { this.setState({userInput: ''}); // 设置值为空字符串 //这里想要实现获得焦点 }, render: function() { return ( <p> <input value={this.state.userInput} onChange={this.handleChange} /> <input type="button" value="Reset And Focus" onClick={this.clearAndFocusInput} /> </p> ); } });
在上面範例中,我們已經實現了點擊按鈕通知input元素將值設為空字串,但是還沒有實現使input元素獲得焦點。這實現起來有些困難,因為在render()中傳回的並不是實際的子元件的組合,只是一個特定時間特定實例的描述。這句話感覺挺繞的,其實render回傳的是虛擬的DOM,並不是真的DOM。因此我們不需要僅僅著眼於那些從render()中返回的那些元件。
那說到這,對於我們如何實現獲得焦點並沒有太大的幫助。要實現獲得焦點這個功能我們需要藉助ref來實現。上面我們提到過ref的值有兩種類型,一種是字串、一種是回呼函數。
ref字串上屬性
React支援一個特殊的屬性,你可以將這個屬性加在任何透過render()傳回的元件中。這也就是說對render()回傳的元件進行一個標記,可以方便的定位的這個元件實例。這就是ref的作用。
ref的形式如下
<input ref="myInput" />
要想存取這個實例,可以透過this.refs來存取:
this.refs.myInput
先前版本中,我們可以透過React.findDOMNode(this .refs.myInput)來存取元件的DOM。但現在,已經放棄了findDOMNode函數了,可以直接用this.refs.myInput來存取。
ref回呼函數
ref屬性也可以是一個回呼函數而不是一個名字。 這個函數將要在元件被掛載之後立即執行。這個參照的元件將會作為該函數的參數,這個函數可以立即使用這個元件參數,當然也可以將其儲存以供日後使用。
其形式也比較簡單:
render: function() { return <TextInput ref={(c) => this._input = c} } />; }, componentDidMount: function() { this._input.focus(); },
或是
render: function() { return ( <TextInput ref={function(input) { if (input != null) { input.focus(); } }} /> ); },
這裡需要注意,當這個參考元件被卸載並且這個ref改變的時候,先前的ref的參數值將為null。這將有效的防止了內存的洩漏。所以在上面程式碼中會有if判斷:
if(input != null){ input.focus(); }
上面介紹了ref的使用場景和方法,下面我們就將上面的例子來補充完整,從而實現獲得焦點的功能
var App = React.createClass({ getInitialState: function() { return {userInput: ''}; }, handleChange: function(e) { this.setState({userInput: e.target.value}); }, clearAndFocusInput: function() { this.setState({userInput: ''}); // Clear the input // We wish to focus the <input /> now! if (this.refs.myTextInput !== null) { this.refs.myTextInput.focus(); } }, render: function() { return ( <p> <input value={this.state.userInput} onChange={this.handleChange} ref=”myTextInput” /> <input type="button" value="Reset And Focus" onClick={this.clearAndFocusInput} /> </p> ); } }); ReactDOM.render( <App />, document.getElementById('content') );
在這個範例中, render 函數傳回一個 實例的描述。但是真正的實例透過 this.refs. myTextInput取得。只要 render 回傳的某個子元件帶有 ref="myTextInput" ,this.refs. myTextInput就會取得正確的實例。
上面是我整理給大家的,希望今後對大家有幫助。
相關文章:
#以上是在React元件中refs的使用方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

如何利用React和WebSocket建立即時聊天應用程式引言:隨著網路的快速發展,即時通訊越來越受到人們的關注。即時聊天應用程式已成為現代社交和工作生活中不可或缺的一部分。本文將介紹如何利用React和WebSocket建立一個簡單的即時聊天應用,並提供具體的程式碼範例。一、技術準備在開始建立即時聊天應用之前,我們需要準備以下技術和工具:React:一個用於構建

React前後端分離指南:如何實現前後端的解耦和獨立部署,需要具體程式碼範例在當今的Web開發環境中,前後端分離已經成為一種趨勢。透過將前端和後端程式碼分開,可以讓開發工作更加靈活、高效,並且方便進行團隊協作。本文將介紹如何使用React實現前後端分離,從而實現解耦和獨立部署的目標。首先,我們要先理解什麼是前後端分離。傳統的Web開發模式中,前端和後端是耦合在

如何利用React和Flask建構簡單易用的網路應用引言:隨著網路的發展,網路應用的需求也越來越多樣化和複雜化。為了滿足使用者對於易用性和效能的要求,使用現代化的技術堆疊來建立網路應用變得越來越重要。 React和Flask是兩個在前端和後端開發中非常受歡迎的框架,它們可以很好的結合在一起,用來建立簡單易用的網路應用。本文將詳細介紹如何利用React和Flask

如何利用React和RabbitMQ建立可靠的訊息傳遞應用程式引言:現代化的應用程式需要支援可靠的訊息傳遞,以實現即時更新和資料同步等功能。 React是一種流行的JavaScript庫,用於建立使用者介面,而RabbitMQ是一種可靠的訊息傳遞中間件。本文將介紹如何結合React和RabbitMQ建立可靠的訊息傳遞應用,並提供具體的程式碼範例。 RabbitMQ概述:

React響應式設計指南:如何實現自適應的前端佈局效果隨著行動裝置的普及和使用者對多螢幕體驗的需求增加,響應式設計成為了現代前端開發的重要考量之一。而React作為目前最受歡迎的前端框架之一,提供了豐富的工具和元件,能夠幫助開發人員實現自適應的佈局效果。本文將分享一些關於使用React實現響應式設計的指南和技巧,並提供具體的程式碼範例供參考。使用React的Fle

React程式碼偵錯指南:如何快速定位並解決前端bug引言:在開發React應用程式時,經常會遇到各種各樣的bug,這些bug可能會使應用程式崩潰或導致不正確的行為。因此,掌握調試技巧是每個React開發者必備的能力。本文將介紹一些定位和解決前端bug的實用技巧,並提供具體的程式碼範例,幫助讀者快速定位和解決React應用程式中的bug。一、調試工具的選擇:在Re

ReactRouter使用指南:如何實現前端路由控制隨著單頁應用的流行,前端路由成為了一個不可忽視的重要部分。 ReactRouter作為React生態系統中最受歡迎的路由庫,提供了豐富的功能和易用的API,使得前端路由的實作變得非常簡單和靈活。本文將介紹ReactRouter的使用方法,並提供一些具體的程式碼範例。安裝ReactRouter首先,我們需要

如何利用React和GoogleBigQuery建立快速的資料分析應用引言:在當今資訊爆炸的時代,資料分析已經成為了各產業中不可或缺的環節。而其中,建構快速、有效率的資料分析應用則成為了許多企業和個人追求的目標。本文將介紹如何利用React和GoogleBigQuery結合來建立快速的資料分析應用,並提供詳細的程式碼範例。一、概述React是用來構建
