国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

react中ref獲取dom或者組件的實現(xiàn)方法

瀏覽:550日期:2022-06-10 09:23:24
目錄
  • react中ref獲取dom或者組件方法
    • 使用ref獲取DOM的引用
    • 使用ref獲取組件的引用
  • react中的三種ref獲取DOM節(jié)點
    • 第一種 ref字符串方式獲取Dom節(jié)點方式
    • 第二種 回調(diào)式獲取Dom節(jié)點方式
    • 第三種 回調(diào)式獲取Dom節(jié)點方式 掛在到自身實例
  • 總結(jié)

    react中ref獲取dom或者組件方法

    使用ref獲取DOM的引用

    在vue中,如果想獲取DOM元素時,可以使用this.$refs.引用名稱

    在react中也可以像vue中,有類似的寫法,如下

    為元素添加ref引用

    <h2 ref="test">這是h2標簽</h2>

    在頁面上獲取元素

    this.refs.test

    使用ref獲取組件的引用

    為組件添加ref引用

    <Text ref="hellow"/>

    在頁面上使用組件的引用

    this.refs.hellow

    注意點: 只要使用ref拿到組件的引用對象,它就是組件的實例對象,因此就可以調(diào)用這個組件的方法,或者它的屬性

    react中的三種ref獲取DOM節(jié)點

    第一種 ref字符串方式獲取Dom節(jié)點方式

    已廢棄的原始方法

    ?? ? class Dom extends React.Component{
    ? ? showInputDom = () =>{
    ? ? ? const {userNameInput} = this.refs
    ? ? ? console.log(userNameInput);
    ? ? }
    ? ? render(){
    ? ? ? return (
    ? ? ? ? <div>
    ? ? ? ? ? <input ref="userNameInput" type="text"/>
    ? ? ? ? ? <button onClick={this.showInputDom}>點擊顯示inpuDom</button>
    ? ? ? ? </div>
    ? ? ? )
    ? ? }
    ? }
    ? ReactDOM.render(<Dom/>,document.getElementById("root"))

    第二種 回調(diào)式獲取Dom節(jié)點方式

    開發(fā)常用

    ?? ?class Dom extends React.Component{
    ? ? showInputDom = () =>{
    ? ? ? const {userNameInput} = this
    ? ? ? console.log(userNameInput);
    ? ? }
    ? ? render(){
    ? ? ? return (
    ? ? ? ? <div>
    ? ? ? ? ? {/*注釋 (currentNode)=>{this.userNameInput =currentNode} 這里邊的currentNode 為 當前的node節(jié)點 簡稱c */}
    ? ? ? ? ? {/*<input ref={(currentNode)=>{this.userNameInput =currentNode}} type="text"/>*/}
    ? ? ? ? ? <input ref={(c)=>{this.userNameInput = c}} type="text"/>
    ? ? ? ? ? <button onClick={this.showInputDom}>點擊顯示inpuDom</button>
    ? ? ? ? </div>
    ? ? ? )
    ? ? }
    ? }
    ? ReactDOM.render(<Dom/>,document.getElementById("root"))

    第三種 回調(diào)式獲取Dom節(jié)點方式 掛在到自身實例

    ?? ? class Dom extends React.Component{
    ? ? // 掛載到了自身實例上了
    ? ? userNameInput= (c) =>{
    ? ? ? this.input1 = c ;
    ? ? ? console.log(c);
    ? ? }
    ? ? render(){
    ? ? ? return (
    ? ? ? ? <div>
    ? ? ? ? ? {/*會在試圖更新時調(diào)用兩次 第一次賦值為null,第二次賦值為dom節(jié)點*/}
    ? ? ? ? ? {/*<input ref={(c)=>{this.userNameInput =c}} type="text"/>*/}
    ? ? ? ? ? {/*在試圖更新時不會調(diào)用}
    ? ? ? ? ? {/*<input ref={ this.userNameInput } type="text"/>*/}
    ? ? ? ? ? {/*注意這倆個方法是有區(qū)別的,這兩個對項目的影響可以忽略不記*/}
    ? ? ? ? ? <input ref={this.userNameInput} type="text"/>
    ? ? ? ? ? <button onClick={this.showInputDom}>點擊顯示inpuDom</button>
    ? ? ? ? </div>
    ? ? ? )
    ? ? }
    ? }
    ? ReactDOM.render(<Dom/>,document.getElementById("root"))

    總結(jié)

    以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持。

    標簽: JavaScript
    主站蜘蛛池模板: 欧美黄色高清 | 亚洲精品第一区二区在线 | 精品 日韩 国产 欧美在线观看 | 久久久精品2018免费观看 | 女人让男人桶的小视频 | 国产精亚洲视频 | 国亚洲欧美日韩精品 | 小泽玛利亚的一级毛片的 | 国产在线视频网址 | 久久精品一区二区影院 | 久操免费| 中文国产成人精品少久久 | 色一欲一性一乱一区二区三区 | 欧美日韩高清在线观看一区二区 | 草久久久久 | 日本最色视频 | 视色4setv.com| 国产蜜汁tv福利在线 | 日韩一级一片 | 广东毛片 | 国产精品爽爽va在线观看无码 | 在线看免费观看韩国特黄一级 | 国产成人综合日韩精品无 | 欧美在线黄 | 国内真实愉拍系列情侣 | 国产成人久久精品二区三区牛 | 国产人成精品综合欧美成人 | 国产香蕉成人综合精品视频 | 毛片美国 | 欧美另类交视频 | 日韩美女强理论片 | 精品在线看| 在线小毛片 | 女人张开腿给人桶免费视频 | 精品日韩一区二区三区 | 欧美综合精品一区二区三区 | 免费国产不卡午夜福在线 | 国产综合精品一区二区 | 一级特黄一欧美俄罗斯毛片 | 国产成人一区二区在线不卡 | 韩国美女爽快一毛片免费 |