• 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属性

    访问当前节点的方式如下:

    this.refs.myref.innerHTML = "hello";
    

    传入对象

    refs通过React.createRef()创建,然后将ref属性添加到React元素中,如下:

    1. class MyComponent extends React.Component {
    2. constructor(props) {
    3. super(props);
    4. this.myRef = React.createRef();
    5. }
    6. render() {
    7. return
      this.myRef} />;
    8. }
    9. }

    当 ref 被传递给 render 中的元素时,对该节点的引用可以在 ref 的 current 属性中访问

    const node = this.myRef.current;
    

    传入函数

    ref传入为一个函数的时候,在渲染过程中,回调函数参数会传入一个元素对象,然后通过实例将对象进行保存

    1. class MyComponent extends React.Component {
    2. constructor(props) {
    3. super(props);
    4. this.myRef = React.createRef();
    5. }
    6. render() {
    7. return
      this.myref = element} />;
    8. }
    9. }

    获取ref对象只需要通过先前存储的对象即可

    const node = this.myref 
    

    传入hook

    通过useRef创建一个ref,整体使用方式与React.createRef一致

    1. function App(props) {
    2. const myref = useRef()
    3. return (
    4. <>
    5. <div ref={myref}></div>
    6. </>
    7. )
    8. }

    获取ref属性也是通过hook对象的current属性

    const node = myref.current;
    

    上述三种情况都是ref属性用于原生HTML元素上,如果ref设置的组件为一个类组件的时候,ref对象接收到的是组件的挂载实例

    注意的是,不能在函数组件上使用ref属性,因为他们并没有实例

    三、应用场景

    在某些情况下,我们会通过使用refs来更新组件,但这种方式并不推荐,更多情况我们是通过propsstate的方式进行去重新渲染子元素

    过多使用refs,会使组件的实例或者是DOM结构暴露,违反组件封装的原则

    例如,避免在 Dialog 组件里暴露 open() 和 close() 方法,最好传递 isOpen 属性

    但下面的场景使用refs非常有用:

    • 对Dom元素的焦点控制、内容选择、控制
    • 对Dom元素的内容设置及媒体播放
    • 对Dom元素的操作和对组件实例的操作
    • 集成第三方 DOM 库
  • 相关阅读:
    Java常用机制 - SPI机制详解
    Excel数学、工程和科学计算插件:FORMULADESK Studio
    计算机毕业设计Java小区综合管理系统(源码+系统+mysql数据库+Lw文档)
    SQLITE_BUSY 是指 SQLite 数据库返回的错误码,表示数据库正在被其他进程或线程使用,因此当前操作无法完成。
    轻量服务器是不是vps ?和vps有什么区别
    软考 系统架构设计师系列知识点之软件构件(1)
    Windows SQLYog连接不上VMbox Ubuntu2204 的Mysql解决方法
    第二章:Spring核心思想和IOC和AOP依赖注入
    Linux 查看程序(动态库)、进程的依赖库的方法
    算法基础入门 - 2.栈、队列、链表
  • 原文地址:https://blog.csdn.net/Ming_xm/article/details/133885481