React refs
面试官:说说对React refs 的理解?应用场景�?

一、是什�?Refs 在计算机中称为弹性文件系统(英语:Resilient File System,简称ReFS�?
React 中的 Refs提供了一种方式,允许我们访问 DOM 节点或在 render 方法中创建的 React 元素
本质为ReactDOM.render()返回的组件实例,如果是渲染组件则返回的是组件实例,如果渲染dom则返回的是具体的dom节点
二、如何使�?
创建ref的形式有三种�?
- 传入字符串,使用时通过 this.refs.传入的字符串的格式获取对应的元素
- 传入对象,对象是通过 React.createRef() 方式创建出来,使用时获取到创建的对象中存�?current 属性就是对应的元素
- 传入函数,该函数会在 DOM 被挂载时进行回调,这个函数会传入一�?元素对象,可以自己保存,使用时,直接拿到之前保存的元素对象即�?- 传入hook,hook是通过 useRef() 方式创建,使用时通过生成hook对象�?current 属性就是对应的元素
传入字符�?
只需要在对应元素或组件中ref属�?
1 | class MyComponent extends React.Component { |
访问当前节点的方式如下:
1 | this.refs.myref.innerHTML = "hello"; |
传入对象
refs通过React.createRef()创建,然后将ref属性添加到React元素中,如下�?
1 | class MyComponent extends React.Component { |
�?ref 被传递给 render 中的元素时,对该节点的引用可以在 ref �?current 属性中访问
1 | const node = this.myRef.current; |
传入函数
当ref传入为一个函数的时候,在渲染过程中,回调函数参数会传入一个元素对象,然后通过实例将对象进行保�?
1 | class MyComponent extends React.Component { |
获取ref对象只需要通过先前存储的对象即�?
1 | const node = this.myref |
传入hook
通过useRef创建一个ref,整体使用方式与React.createRef一�?
1 | function App(props) { |
获取ref属性也是通过hook对象的current属�?
1 | const node = myref.current; |
上述三种情况都是ref属性用于原生HTML元素上,如果ref设置的组件为一个类组件的时候,ref对象接收到的是组件的挂载实例
注意的是,不能在函数组件上使用ref属性,因为他们并没有实�?
三、应用场�?
在某些情况下,我们会通过使用refs来更新组件,但这种方式并不推荐,更多情况我们是通过props与state的方式进行去重新渲染子元�?
过多使用refs,会使组件的实例或者是DOM结构暴露,违反组件封装的原则
例如,避免在 Dialog 组件里暴�?open() �?close() 方法,最好传�?isOpen 属�?
但下面的场景使用refs非常有用�?
- 对Dom元素的焦点控制、内容选择、控�?- 对Dom元素的内容设置及媒体播放
- 对Dom元素的操作和对组件实例的操作
- 集成第三�?DOM �?