亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React組件refs該如何使用

發布時間:2021-01-19 14:27:52 來源:億速云 閱讀:154 作者:小新 欄目:移動開發

小編給大家分享一下React組件refs該如何使用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

ref顧名思義我們知道,其實它就可以被看座是一個組件的參考,也可以說是一個標識。作為組件的屬性,其屬性值可以是一個字符串也可以是一個函數。

其實,ref的使用不是必須的。即使是在其適用的場景中也不是非用不可的,因為使用ref實現的功能同樣可以轉化成其他的方法來實現。但是,既然ref有其適用的場景,那也就是說ref自有其優勢。關于這一點和ref的適用場景,官方文檔中是這樣說的:

在從 render 方法中返回 UI 結構之后,你可能想沖出 React 虛擬 DOM 的限制,在 render 返回的組件實例上調用某些方法。通常來說,這樣做對于應用中的數據流動是不必要的,因為活躍的數據( Reactive data )流總是確保最新的 props 被傳遞到每一個從 render() 輸出的子級中去。然而,仍然有幾個場景使用這種方式是必須的,或者說是有益的:查找渲染出的組件的DOM標記(可以認為是DOM的標識ID),在一個大型的非React應用中使用React組件或者是將你現有的代碼轉化成React。

下面我們來看這樣的一個場景(下面的例子經常被用于ref的講解,可見下面描述的場景應該是比較經典的):通過某個事件使<input />元素的值被設為空字符串,然后使該<input />元素獲得焦點。

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 函數返回一個 <input /> 實例的描述。但是真正的實例通過 this.refs. myTextInput獲取。只要 render 返回的某個子組件帶有 ref="myTextInput" ,this.refs. myTextInput就會獲取到正確的實例。

以上是“React組件refs該如何使用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁阳县| 瑞丽市| 绿春县| 聊城市| 连云港市| 达州市| 娄底市| 华安县| 赣榆县| 博客| 普宁市| 时尚| 达州市| 观塘区| 平阴县| 疏勒县| 扬州市| 湖南省| 拉孜县| 河北区| 红安县| 平邑县| 兴文县| 庆阳市| 亚东县| 称多县| 钦州市| 望江县| 阿荣旗| 乌鲁木齐县| 和龙市| 万荣县| 正定县| 昌都县| 新宁县| 巴林左旗| 宁安市| 清涧县| 峨眉山市| 大足县| 土默特右旗|