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
方法可以获得