React三大属性之refs

前言

javascript 复制代码
<div id="test"></div>
<script type="text/babel">
    class Demo extends React.Component{
        showData = ()=>{
            const inputValue = document.getElementById("input")
            alert(inputValue)
        }
        render(){
            return (
                <input type="text" id="input" />
                <button onClick="{ this.showData }"></button>
            )
        }
    }

    ReactDOM.render(<Demo />,document.getElementById("test"))
</script>

以上,我们给按钮绑定了一个事件,通过原生的选择器获取了输入框的这个DOM,输出了输入框里的内容。

组件内的标签可以定义ref属性来标识自己

1、字符串式ref

javascript 复制代码
<div id="test"></div>
<script type="text/babel">
    class Demo extends React.Component{

        showData = ()=>{
            alert(this.refs.input1.value)
        }
        showData2 = ()=>{
            alert(this.refs.input2.value)
        } 

        render(){
            return (
                <input type="text" ref="input1"/>
                <button onClick="{ this.showData }"></button>
                <input type="text" ref="input2" onBlur="{ this.showData2 }" />
            )
        }
    }

    ReactDOM.render(<Demo />,document.getElementById("test"))
</script>

这里的在标签中添加ref类似于vue2的ref的使用

字符串类型的refs存在效率低的问题,未来版本可能会移除

2、回调函数类型的ref

javascript 复制代码
<div id="test"></div>
<script type="text/babel">
    class Demo extends React.Component{
        showData = ()=>{
            const input1 = this
            alert(input1.value)
        }
        render(){
            return (
                <input type="text" ref={ c=>this.input1 = c } />
                <button onClick="{ this.showData }"></button>
            )
        }
    }

    ReactDOM.render(<Demo />,document.getElementById("test"))
</script>

解释

ref={ c=>this.input1 = c } 这个代码实际是 ref={ (c)=>{ this.input1 = c } },而这个C打印的话,可以发现它所代表的是input这个DOM。

3、回调ref的执行次数

javascript 复制代码
 <input type="text" ref={ c=>this.input1 = c } />

官网中说:如果ref回调函数是以内联函数的方式定义的,在更新过程中,它会被执行两次,第一次传入参数 null ,然后第二次传入参数DOM元素,这是因为在每次渲染时会创建一个新的函数梳理,所以React清空旧的ref并且设置新的。通过将ref的回调函数定义成class的绑定函数的方式就可以避免上述问题,但是大多数情况下它是无关紧要的。

我们之前说过render这个函数的执行次数是1+n次,当运行时,该标签发生的更新,那这个ref的执行就会次数就会+2。

ref的回调函数定义成class的绑定函数的方式

javascript 复制代码
<div id="test"></div>
<script type="text/babel">
    class Demo extends React.Component{
        showData = ()=>{
            const { input1 } = this
            alert(input1.value)
        }

        showInput=(c)=>{
            this.input1 = c
            //这个c就是input这个DOM
        }
        render(){
            return (
                //在JSX语法中,如果想注释一些html代码,可以使用 { /*     */ }的形式注释
                //因为在JSX中,{}里可以写js代码
                {/*<input type="text" ref={ c=>this.input1 } />*/}


                <input type="text" ref={ this.showInput } />
                <button onClick="{ this.showData }"></button>
            )
        }
    }

    ReactDOM.render(<Demo />,document.getElementById("test"))
</script>

4、createRef的使用

React.createRef调用后可以返回一个容器,该容器可以存储被ref所标识的节点,该节点是专人专用,也就是只能存储一个DOM

javascript 复制代码
<div id="test"></div>
<script type="text/babel">
    class Demo extends React.Component{
        
        myRef = React.createRef()

        showData = ()=>{
            alert(this.myRef.current.value)
        } 

        render(){
            return (
                <input type="text" ref="{ this.myRef }"/>
                <button onClick="{ this.showData }"></button>
            )
        }
    }

    ReactDOM.render(<Demo />,document.getElementById("test"))
</script>
相关推荐
why技术5 分钟前
AI Coding开始进入第四个时代,我还没上车呢!
前端·人工智能·后端
大家的林语冰1 小时前
CSS 已死?DOM 性能黑洞!Pretext 排版革命让你在文本间跳舞,没有 DOM 也能纵享丝滑~
前端·javascript·css
vipbic1 小时前
我也该升级了,陪伴了我7年的博客
前端
Lee川1 小时前
RAG 实战:从一篇掘金文章出发,拆解检索增强生成的全链路
前端·人工智能·后端
Lee川2 小时前
MCP 高德地图实战:当 AI 学会使用工具,一个协议如何重塑大模型的行动边界
前端·人工智能·后端
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_14:(尺寸调整技能测试与实战解析)
前端·css·ui·html·tensorflow
kyriewen2 小时前
用魔法打败魔法:我让AI替我去面试前端岗,AI面试官给我打了92分,还发了offer
前端·javascript·面试
IT_陈寒2 小时前
Redis批量删除踩了坑,原来DEL命令不是万能的
前端·人工智能·后端
lichenyang4532 小时前
鸿蒙聊天 Demo 练习 06:AI 思考气泡与 MVVM + Controller 结构重构
前端
Lkstar3 小时前
Vue keep-alive 原理全解:LRU 缓存策略、源码级理解
前端·vue.js·面试