react-----dom对象和useref()

获取原生dom方法

方法1:
使用传统的docunment

方法二
直接从react处获取dom对象,创建存储dom对象的容器

使用useRef()这个钩子函数,钩子函数的注意事项:

1.钩子函数只能用于函数组件或者自定义钩子

2.钩子函数只能直接在函数组件中调用不能写在组件里面的函数中
在这里插入图片描述

3.将容器设置为想要获取dom对象元素的ref属性

<h1 ref={xxx}>...</h1>

react会自动将当前元素的dom对象,设置为容器的current属性

如果我们需要获得div的原生dom怎么办?

    const clickHandler=()=>{
        console.log(h1Ref);
        alert(h1Ref.current)
    }

    return <div className="App" ref={h1Ref}>
        <h1 id="header">我是标题</h1>
        <button onClick={clickHandler}>1</button>
        <button >2</button>
    </div>

你叫h1ref你放div那里干嘛?

你想获取谁就把它放在哪里,比如说你想获取h1的,你就放在这里

    return <div className="App" >
        <h1 id="header" ref={h1Ref}>我是标题</h1>
        <button onClick={clickHandler}>1</button>
        <button >2</button>
    </div>

我们的dom对象在h1Ref.current这个里面,我们的h1ref只是一个容器。

我们通过原生方法和我们react方法===最后的结果是true,说明是同一个东西

uesref()这个容器返回的就是一个普通的js对象{current:undefine}

思考:既然我们返回的就是这个为什么我不直接返回这个东西
所以我们创建一个js对象也可以代替useref(),自己创建的const h1ref={current:null}

会出现什么问题?????
我们创建的对象在函数里面,每一次重新渲染都会创建新的对象,每一次都是一个新对象

什么时候使用useref()?
当需要一个对象不会因为组建的重新渲染而改变的时候就可以使用useRef()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值