React之ref

React提供的這個ref屬性,表示為對組件真正實例的引用时捌,其實就是ReactDOM.render()返回的組件實例;

  • ReactDOM.render()渲染組件時返回的是組件實例;
  • 渲染dom元素時逗威,返回是具體的dom節(jié)點蚌讼。

ref可以掛載到組件上也可以是dom元素上辟灰;

  • 掛到組件(class聲明的組件)上的ref表示對組件實例的引用。不能在函數(shù)式組件上使用 ref 屬性篡石,因為它們沒有實例:
  • 掛載到dom元素上時表示具體的dom元素節(jié)點芥喇。

Q:ref屬性可以設(shè)置為一個回調(diào)函數(shù)
React 支持給任意組件添加特殊屬性。ref 屬性接受一個回調(diào)函數(shù)凰萨,它在組件被加載或卸載時會立即執(zhí)行继控。

  • 當(dāng)給 HTML 元素添加 ref 屬性時械馆,ref 回調(diào)接收了底層的 DOM 元素作為參數(shù)。
  • 當(dāng)給組件添加 ref 屬性時武通,ref 回調(diào)接收當(dāng)前組件實例作為參數(shù)霹崎。
  • 當(dāng)組件卸載的時候,會傳入null
  • ref 回調(diào)會在componentDidMount 或 componentDidUpdate 這些生命周期回調(diào)之前執(zhí)行冶忱。

Q:當(dāng)給組件尾菇、H5標簽添加 ref 屬性后,此實例只能在當(dāng)前組件中被訪問到朗和,父組件的 refs 中是沒有此引用的错沽,例如:

var Parent = React.createClass({
  render: function(){
    return (
      <div className = 'parent'>
        <Child ref = 'child'/>
      </div>
    )
  },
  componentDidMount(){
    console.log(this.refs.child); // 訪問掛載在組件上ref
    console.log(this.refs.child.refs.update); // 訪問掛載在dom元素上的ref
  }
})

var Child = React.createClass({
  render: function() {
    return (
        <div ref="test">
          <a ref="update">更新</a>
        </div>
    );
  }
});
ReactDOM.render(
  <Parent/>,
  document.getElementById('example')
);
image.png
  • 給 h5 元素設(shè)置 ref <a ref="update">更新</a>后,可以拿到它的真實 dom<a>更新</a>眶拉。
  • 給組件設(shè)置ref<Child ref = 'child'/>后千埃,拿到的是組件的實例(上圖中的Constructor)

Q:獲取ref引用組件對應(yīng)的dom節(jié)點
不管ref設(shè)置值是回調(diào)函數(shù)還是字符串,都可以通過ReactDOM.findDOMNode(ref)來獲取組件掛載后真正的dom節(jié)點忆植。


image.png

image.png

但是對于html元素使用ref的情況放可,ref本身引用的就是該元素的實際dom節(jié)點,無需使用ReactDOM.findDOMNode(ref)來獲取朝刊,該方法常用于React組件上的ref耀里。

Q:this.refsReactDOM.findDOMNode的區(qū)別

  • ref添加到Compoennt上獲取的是Compoennt實例,添加到原生HTML上獲取的是DOM拾氓;
  • ReactDOM.findDOMNode冯挎,當(dāng)參數(shù)是DOM,返回值就是該DOM咙鞍;當(dāng)參數(shù)是Component獲取的是該Component render方法中的DOM
  • 二者主要區(qū)別在ref綁定在組件上的時候房官,this.refs獲取到的是組件實例,ReactDOM.findDOMNode獲取到的是dom節(jié)點续滋。

Q:新版本的React已經(jīng)不推薦我們使用ref string轉(zhuǎn)而使用ref callback

<Child ref={child => this._child = child}/>
console.log(ReactDOM.findDOMNode(this._child))
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末翰守,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子疲酌,更是在濱河造成了極大的恐慌蜡峰,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件朗恳,死亡現(xiàn)場離奇詭異湿颅,居然都是意外死亡,警方通過查閱死者的電腦和手機粥诫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門肖爵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人臀脏,你說我怎么就攤上這事劝堪。” “怎么了揉稚?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵秒啦,是天一觀的道長。 經(jīng)常有香客問我搀玖,道長余境,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任灌诅,我火速辦了婚禮芳来,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘猜拾。我一直安慰自己即舌,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布挎袜。 她就那樣靜靜地躺著顽聂,像睡著了一般。 火紅的嫁衣襯著肌膚如雪盯仪。 梳的紋絲不亂的頭發(fā)上紊搪,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天,我揣著相機與錄音全景,去河邊找鬼耀石。 笑死,一個胖子當(dāng)著我的面吹牛爸黄,可吹牛的內(nèi)容都是我干的滞伟。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼馆纳,長吁一口氣:“原來是場噩夢啊……” “哼诗良!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起鲁驶,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤鉴裹,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后钥弯,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體径荔,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年脆霎,在試婚紗的時候發(fā)現(xiàn)自己被綠了总处。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡睛蛛,死狀恐怖鹦马,靈堂內(nèi)的尸體忽然破棺而出胧谈,到底是詐尸還是另有隱情,我是刑警寧澤荸频,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布菱肖,位于F島的核電站,受9級特大地震影響旭从,放射性物質(zhì)發(fā)生泄漏稳强。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一和悦、第九天 我趴在偏房一處隱蔽的房頂上張望退疫。 院中可真熱鬧,春花似錦鸽素、人聲如沸褒繁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽澜汤。三九已至,卻和暖如春舵匾,著一層夾襖步出監(jiān)牢的瞬間俊抵,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工坐梯, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留徽诲,地道東北人。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓吵血,卻偏偏與公主長得像谎替,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蹋辅,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 以下內(nèi)容是我在學(xué)習(xí)和研究React時钱贯,對React的特性、重點和注意事項的提取侦另、精練和總結(jié)秩命,可以做為React特性...
    科研者閱讀 8,232評論 2 21
  • React Native之React速學(xué)教程(上) 本文出自《React Native學(xué)習(xí)筆記》系列文章。 Rea...
    CrazyCodeBoy閱讀 2,367評論 1 43
  • react 基本概念解析 react 的組件聲明周期 react 高階組件褒傅,context, redux 等高級...
    南航閱讀 1,069評論 0 1
  • 人生是一場永不落幕的演出殿托,我們每一個人都是演員霹菊,只不過,有的人順從自己支竹,有的人取悅觀眾旋廷。 這世界是不公平的鸠按。傷你最...
    我是彭公子閱讀 382評論 0 0
  • 來不及 沒有更多的時間 去兌換 有你的季節(jié)
    shin_35d3閱讀 136評論 0 0