深入浅析React|深入浅析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
属性class MyComponent extends React.Component {constructor(props) {super(props); this.myRef = React.createRef(); }render() {return ; }}
访问当前节点的方式如下:
this.refs.myref.innerHTML = "hello";
传入对象
refs
通过React.createRef()
创建,然后将ref
属性添加到React
元素中,如下:class MyComponent extends React.Component {constructor(props) {super(props); this.myRef = React.createRef(); }render() {return ; }}
【深入浅析React|深入浅析React refs的简介】当
ref
被传递给render
中的元素时,对该节点的引用可以在ref
的current
属性中访问const node = this.myRef.current;
传入函数
当
ref
传入为一个函数的时候,在渲染过程中,回调函数参数会传入一个元素对象,然后通过实例将对象进行保存class MyComponent extends React.Component {constructor(props) {super(props); this.myRef = React.createRef(); }render() {returnthis.myref = element} />; }}
获取
ref
对象只需要通过先前存储的对象即可const node = this.myref
传入hook
通过
useRef
创建一个ref
,整体使用方式与React.createRef
一致function App(props) {const myref = useRef()return (<>>)}
获取
ref
属性也是通过hook
对象的current
属性const node = myref.current;
上述三种情况都是
ref
属性用于原生HTML
元素上,如果ref
设置的组件为一个类组件的时候,ref
对象接收到的是组件的挂载实例注意的是,不能在函数组件上使用
ref
属性,因为他们并没有实例三、应用场景 在某些情况下,我们会通过使用
refs
来更新组件,但这种方式并不推荐,更多情况我们是通过props
与state
的方式进行去重新渲染子元素过多使用
refs
,会使组件的实例或者是DOM
结构暴露,违反组件封装的原则例如,避免在
Dialog
组件里暴露open()
和close()
方法,最好传递isOpen
属性但下面的场景使用
refs
非常有用:- 对Dom元素的焦点控制、内容选择、控制
- 对Dom元素的内容设置及媒体播放
- 对Dom元素的操作和对组件实例的操作
- 集成第三方 DOM 库
推荐阅读
- 深入理解Go之generate
- 【1057快报】深入机关,走下田间,交通普法,共创文明
- 生发知识,带你深入了解
- 深入理解|深入理解 Android 9.0 Crash 机制(二)
- react|react 安装
- 深入浅出谈一下有关分布式消息技术(Kafka)
- React.js学习笔记(17)|React.js学习笔记(17) Mobx
- React.js的表单(六)
- 【React|【React Native填坑之旅】从源码角度看JavaModule注册及重载陷阱
- react-navigation|react-navigation 动态修改 tabBar 样式