小編給大家分享一下React組件refs該如何使用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)公司是一家專業(yè)的成都網(wǎng)站建設(shè)公司,我們專注網(wǎng)站設(shè)計(jì)制作、成都做網(wǎng)站、網(wǎng)絡(luò)營(yíng)銷、企業(yè)網(wǎng)站建設(shè),外鏈,廣告投放為企業(yè)客戶提供一站式建站解決方案,能帶給客戶新的互聯(lián)網(wǎng)理念。從網(wǎng)站結(jié)構(gòu)的規(guī)劃UI設(shè)計(jì)到用戶體驗(yàn)提高,創(chuàng)新互聯(lián)力求做到盡善盡美。ref顧名思義我們知道,其實(shí)它就可以被看座是一個(gè)組件的參考,也可以說(shuō)是一個(gè)標(biāo)識(shí)。作為組件的屬性,其屬性值可以是一個(gè)字符串也可以是一個(gè)函數(shù)。
其實(shí),ref的使用不是必須的。即使是在其適用的場(chǎng)景中也不是非用不可的,因?yàn)槭褂胷ef實(shí)現(xiàn)的功能同樣可以轉(zhuǎn)化成其他的方法來(lái)實(shí)現(xiàn)。但是,既然ref有其適用的場(chǎng)景,那也就是說(shuō)ref自有其優(yōu)勢(shì)。關(guān)于這一點(diǎn)和ref的適用場(chǎng)景,官方文檔中是這樣說(shuō)的:
在從 render 方法中返回 UI 結(jié)構(gòu)之后,你可能想沖出 React 虛擬 DOM 的限制,在 render 返回的組件實(shí)例上調(diào)用某些方法。通常來(lái)說(shuō),這樣做對(duì)于應(yīng)用中的數(shù)據(jù)流動(dòng)是不必要的,因?yàn)榛钴S的數(shù)據(jù)( Reactive data )流總是確保新的 props 被傳遞到每一個(gè)從 render() 輸出的子級(jí)中去。然而,仍然有幾個(gè)場(chǎng)景使用這種方式是必須的,或者說(shuō)是有益的:查找渲染出的組件的DOM標(biāo)記(可以認(rèn)為是DOM的標(biāo)識(shí)ID),在一個(gè)大型的非React應(yīng)用中使用React組件或者是將你現(xiàn)有的代碼轉(zhuǎn)化成React。
下面我們來(lái)看這樣的一個(gè)場(chǎng)景(下面的例子經(jīng)常被用于ref的講解,可見(jiàn)下面描述的場(chǎng)景應(yīng)該是比較經(jīng)典的):通過(guò)某個(gè)事件使元素的值被設(shè)為空字符串,然后使該元素獲得焦點(diǎn)。
var App = React.createClass({ getInitialState: function() { return {userInput: ''}; }, handleChange: function(e) { this.setState({userInput: e.target.value}); }, clearAndFocusInput: function() { this.setState({userInput: ''}); // 設(shè)置值為空字符串 //這里想要實(shí)現(xiàn)獲得焦點(diǎn) }, render: function() { return (); } });
在上面例子中,我們已經(jīng)實(shí)現(xiàn)了點(diǎn)擊按鈕通知input元素將值設(shè)為空字符串,但是還沒(méi)有實(shí)現(xiàn)使input元素獲得焦點(diǎn)。這實(shí)現(xiàn)起來(lái)有些困難,因?yàn)樵趓ender()中返回的并不是實(shí)際的子組件的組合,僅僅是一個(gè)特定時(shí)間特定實(shí)例的描述。這句話感覺(jué)挺繞的,其實(shí)render返回的是虛擬的DOM,并不是真實(shí)的DOM。因此我們不需要僅僅著眼于那些從render()中返回的那些組件。
那說(shuō)到這,對(duì)于我們?nèi)绾螌?shí)現(xiàn)獲得焦點(diǎn)并沒(méi)有太大的幫助。要想實(shí)現(xiàn)獲得焦點(diǎn)這個(gè)功能我們需要借助ref來(lái)實(shí)現(xiàn)。上面我們提到過(guò)ref的值有兩種類型,一種是字符串、一種是回調(diào)函數(shù)。
ref字符串上屬性
React支持一個(gè)特殊的屬性,你可以將這個(gè)屬性加在任何通過(guò)render()返回的組件中。這也就是說(shuō)對(duì)render()返回的組件進(jìn)行一個(gè)標(biāo)記,可以方便的定位的這個(gè)組件實(shí)例。這就是ref的作用。
ref的形式如下
要想訪問(wèn)這個(gè)實(shí)例,可以通過(guò)this.refs來(lái)訪問(wèn):
this.refs.myInput
先前版本中,我們可以通過(guò)React.findDOMNode(this.refs.myInput)來(lái)訪問(wèn)組件的DOM。但是現(xiàn)在,已經(jīng)放棄了findDOMNode函數(shù)了,可以直接使用this.refs.myInput來(lái)進(jìn)行訪問(wèn)。
ref回調(diào)函數(shù)
ref屬性也可以是一個(gè)回調(diào)函數(shù)而不是一個(gè)名字。 這個(gè)函數(shù)將要在組件被掛載之后立即執(zhí)行。這個(gè)參照的組件將會(huì)作為該函數(shù)的參數(shù),這個(gè)函數(shù)可以立即使用這個(gè)組件參數(shù),當(dāng)然也可以將其保存供以后使用。
其形式也比較簡(jiǎn)單:
render: function() { returnthis._input = c} } />; }, componentDidMount: function() { this._input.focus(); },
或者是
render: function() { return (); },
這里需要注意,當(dāng)這個(gè)參照組件被卸載并且這個(gè)ref改變的時(shí)候,先前的ref的參數(shù)值將為null。這將有效的防止了內(nèi)存的泄露。所以在上面代碼中會(huì)有if判斷:
if(input != null){ input.focus(); }
上面介紹了ref的使用場(chǎng)景和方法,下面我們就將上面的例子來(lái)補(bǔ)充完整,從而實(shí)現(xiàn)獲得焦點(diǎn)的功能
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 now! if (this.refs.myTextInput !== null) { this.refs.myTextInput.focus(); } }, render: function() { return (); } }); ReactDOM.render(
, document.getElementById('content') );
在這個(gè)例子中, render 函數(shù)返回一個(gè) 實(shí)例的描述。但是真正的實(shí)例通過(guò) this.refs. myTextInput獲取。只要 render 返回的某個(gè)子組件帶有 ref="myTextInput" ,this.refs. myTextInput就會(huì)獲取到正確的實(shí)例。
以上是“React組件refs該如何使用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!