ref是React提供的用来操纵React组件实例或者DOM元素的接口;回调函数就是在dom节点或组件上挂载函数,函数的入参是dom节点或组件实例,达到的效果与字符串形式是一样的,都是获取其引用。
在react典型的数据流中,props
传递是父子组件交互的唯一方式;通过传递一个新的props
值来使子组件重新re-render
,从而达到父子组件通信。当然,就像react官网所描述的一样,在react典型的数据量之外,某些情况下(例如和第三方的dom库整合,或者某个dom元素focus等)为了修改子组件我们可能需要另一种方式,这就是ref
方式。
React提供的这个ref
属性,表示为对组件真正实例的引用,其实就是ReactDOM.render()返回的组件实例
;需要区分一下,ReactDOM.render()
渲染组件时返回的是组件实例;而渲染dom元素时,返回是具体的dom节点。
例如,下面代码:
const domCom = ; const refDom = ReactDOM.render(domCom,container); //ConfirmPass的组件内容省略 const refCom = ReactDOM.render(,container); console.log(refDom); console.log(refCom);
上述代码返回控制台结果如下图所示:
ref
可以挂到任何组件上,可以挂到组件上也可以是dom元素上;二者不同是与上图答案一样:
挂到组件(这里组件指的是有状态组件)上的ref表示对组件实例的引用,而挂载到dom元素上时表示具体的dom元素节点。
ref属性可以设置为一个回调函数,这也是官方强烈推荐的用法;这个函数执行的时机为:
组件被挂载后
,回调函数被立即执行,回调函数的参数为该组件的具体实例。
组件被卸载或者原有的ref属性本身发生变化时
,回调也会被立即执行,此时回调函数参数为null
,以确保内存泄露。