Refs
在计算机中称为弹性文件系统(英语:Resilient File System,简称ReFS)
React
中的 Refs
提供了一种方式,允许我们访问 DOM
节点或在 render
方法中创建的 React
元素
本质为ReactDOM.render()
返回的组件实例,如果是渲染组件则返回的是组件实例,如果渲染dom
则返回的是具体的dom
节点
创建ref
的形式有三种:
只需要在对应元素或组件中ref
属性
访问当前节点的方式如下:
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 this.myRef} />;
- }
- }
当 ref
被传递给 render
中的元素时,对该节点的引用可以在 ref
的 current
属性中访问
const node = this.myRef.current;
传入函数
当ref
传入为一个函数的时候,在渲染过程中,回调函数参数会传入一个元素对象,然后通过实例将对象进行保存
- class MyComponent extends React.Component {
- constructor(props) {
- super(props);
- this.myRef = React.createRef();
- }
- render() {
- return this.myref = element} />;
- }
- }
获取ref
对象只需要通过先前存储的对象即可
const node = this.myref
传入hook
通过useRef
创建一个ref
,整体使用方式与React.createRef
一致
- function App(props) {
- const myref = useRef()
- return (
- <>
- <div ref={myref}></div>
- </>
- )
- }
获取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 库
-
相关阅读:
jmeter参数化导致反斜杠(\)被转义
Angular distance
ubuntu docker 部署 vue 项目
【王道】计算机组成原理第六章总线(六)
4个Javascript中的for循环
电子统计台账:设置能自动合并数据的垂直过滤模板
41. Linux系统配置FTP服务器并在QT中使用QFtp实现文件上传
java 的抽象(abstract)和接口(interface)的区别
【剑指】数组中的重复数字
frp内网穿透并搭建多个域名同时映射
-
原文地址:https://blog.csdn.net/Ming_xm/article/details/133885481