React Ref的使用

React 支持一种非常特殊的属性 Ref ,你可以用来绑定到 render() 输出的任何组件上。这个特殊的属性允许你引用 render() 返回的相应的支撑实例( backing instance )。这样就可以确保在任何时间总是拿到正确的实例。

ref可以挂载到组件或者DOM元素上,挂到组件(有状态组件)上的ref表示对组件实例的引用,而挂载到dom元素上时表示具体的dom元素节点。

使用ref获取dom元素

在做项目的过程中不可避免的要直接操作DOM元素,这是因为需要与第三方库交互,需要获取DOM元素然后调用库。

ref回调函数
  • 组件被挂载后,回调函数被立即执行,回调函数的参数为该组件的具体实例。
  • 组件被卸载或者原有的ref属性本身发生变化时,回调也会被立即执行,此时回调函数参数为null,以免内存泄露。
<div
    key={index}
    className='node data'
    ref={dom_node => this.refs.nodes_left[index]= dom_node}
>
</div>

这里使用ref属性,挂载一个回调函数,在渲染DOM的时候将真实DOM节点传入this.refs.nodes_left这个数组。

nodeData_left.map((node, index) => {
    this.setState({nodes: node}, () => {
        this.initNodes(this.refs.nodes_left[index], 'left');
    });
})

获取到ref上所需的dom元素后,进行与第三方库的操作。

this.setState({}, () => {});

这个回调函数在state更新完毕后立即执行。就是说ref是在render时赋值的,state更新也是在render时执行的,两者可以说是同时完成,当state更新后此时ref也肯定已经赋值,所以将获取ref值操作的函数写在setState的回调函数中。

关于ref的使用方式

1.字符串形式
<div ref="mydiv"></div>
console.log(this.refs.myinput)
2.ref访问有状态组件

ref用到react有状态组件时,ref引用的是组件的实例;可以通过子组件的ref可以访问到子组件实例的props、state、refs、实例方法(非继承而来的方法)。

3.ref访问无状态组件

因为无状态组件不会被实例化的,在父组件中通过ref来获取无状态子组件时,其值为null。但是在无状态组件中可以使用某个变量来保存dom元素,之后再读取这个变量的值。

4.ReactDOM.findDOMNode(ref)

通过以上方式获取的不是真正的dom节点,使用ReactDOM.findDOMNode方法可以获得

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 3. JSX JSX是对JavaScript语言的一个扩展语法, 用于生产React“元素”,建议在描述UI的时候...
    pixels阅读 7,951评论 0 24
  • It's a common pattern in React to wrap a component in an ...
    jplyue阅读 8,546评论 0 2
  • 深入JSX date:20170412笔记原文其实JSX是React.createElement(componen...
    gaoer1938阅读 12,480评论 2 35
  • 说在前面 关于 react 的总结过去半年就一直碎碎念着要搞起来,各(wo)种(tai)原(lan)因(le)。心...
    陈嘻嘻啊阅读 11,825评论 7 41
  • 背景:每天早晨九点进行微信推送,用户3-4万人 技术瓶颈:php为弱类型的语言,从头执行到尾,导致推送时长长大2个...
    张兆强阅读 2,241评论 0 2

友情链接更多精彩内容