React系列之Ref

本篇博客介绍 React中的Ref知识,包含函数组件和类组件

作用

RefReact中,通常用来处理对DOM的操作,例如聚焦输入框、控制子组件等等。

类组件

在类组件中,有以下三种写法:

  • 字符串
  • callback
  • createRef

字符串

「已弃用」: 向标签的ref属性传入一个字符串,即可在this.refs的属性中访问到。

jsx 复制代码
import React from 'react';

export default class ClassRef extends React.Component {
  getRef = () => {
    console.log(this.refs.abc);
  };
  render() {
    return (
      <div>
        <h1>类组件Ref 使用字符串形式</h1>
        <input ref="abc" type="text" />
        <button onClick={this.getRef}>获取ref</button>
      </div>
    );
  }
}

callback

使用refcallback形式,将ref赋值给一个自定义变量。

js 复制代码
ref={ref => xxx = ref}
jsx 复制代码
import React from 'react';

export default class ClassRef extends React.Component {
  ref = '';
  getRef = () => {
    console.log('使用callback形式', this.ref);
  };
  render() {
    return (
      <div>
        <h1>类组件Ref callback形式</h1>
        <input ref={(e) => (this.ref = e)} type="text" />
        <button onClick={this.getRef}>获取ref</button>
      </div>
    );
  }
}

createRef

createRef通常在类组件中使用,包含一个current属性,这个属性指向指定的内容。

jsx 复制代码
import React, {createRef} from 'react';

export default class ClassRef extends React.Component {
  cRef = createRef();
  getRef = () => {
    console.log('使用createRef形式', this.cRef.current);
  };
  render() {
    return (
      <div>
        <h1>类组件Ref createRef形式</h1>
        <input ref={this.cRef} type="text" />
        <button onClick={this.getRef}>获取ref</button>
      </div>
    );
  }
}

函数组件

由于函数组件没有this,所以这里比类组件少一种形式

  • callback
  • useRef「常用」

callback

同样的,将ref保存在一个变量中。

jsx 复制代码
export default function FuncRef(props) {
  let inputRef;
  const getRef = () => {
    console.log('使用callback形式',inputRef);
  };
  return (
    <div>
      <h1>函数组件Ref callback形式</h1>
      <input ref={(e) => (inputRef = e)} type="text" />
      <button onClick={getRef}>获取ref</button>
    </div>
  );
};

useRef

useRef通常在函数组件中使用,同样也有一个current属性,指向指定的内容。

jsx 复制代码
export default function FuncRef() {
  const getRef = () => {
    console.log('使用useRef形式', handleRef.current);
  };
  const handleRef = useRef();
  return (
    <div>
      <h1>函数组件Ref useRef形式</h1>
      <input ref={handleRef} type="text" />
      <button onClick={getRef}>获取ref</button>
    </div>
  );
};

注意

  • 组件ref

    以上的示例代码的使用方式中虽然只举例了对原生元素的引用使用情况,但ref也是可以在自定义组件上使用。

    但这里有一个需要注意的地方:函数组件在被ref引用的时候,需要使用forwardRef进行ref转发,同时可以搭配useImperativeHandlehook函数来控制暴露出去的内容。

jsx 复制代码
import {useImperativeHandle, useRef, forwardRef} from 'react';

export default forwardRef(function FuncRef(props, ref) {
  useImperativeHandle(ref, () => {
    return {
      a: 1,
      b: 2,
      ref: handleRef.current,
    };
  });
  const handleRef = useRef();
  return (
    <div>
      <h1>函数组件Ref 被使用的情况</h1>
      <input ref={handleRef} type="text" />
    </div>
  );
});
  • useRefcreateRef区别
    • useRef只能在函数组件中使用,createRef在类组件、函数组件都可以使用
    • useRef具有缓存作用;若在函数组件使用createRef,随着每次页面更新,都会创建新的createRef

总结

本文总结了React中的Ref在类组件和函数组件中的使用方式;虽然在目前的趋势下,主要是使用函数式组件进行开发,但也不乏在工作中会遇到之前用类组件写的项目,所以同时掌握两种类型的Ref写法还是很有必要的。

相关推荐
Bellafu6661 小时前
selenium 常用xpath写法
前端·selenium·测试工具
blackorbird3 小时前
Edge 浏览器 IE 模式成攻击突破口:黑客借仿冒网站诱导攻击
前端·edge
谷歌开发者4 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (一)
前端·chrome·学习
名字越长技术越强4 小时前
Chrome和IE获取本机ip地址
前端
天***88964 小时前
Chrome 安装失败且提示“无可用的更新” 或 “与服务器的连接意外终止”,Chrome 离线版下载安装教程
前端·chrome
半梦半醒*4 小时前
zabbix安装
linux·运维·前端·网络·zabbix
大怪v5 小时前
【搞发🌸活】不信书上那套理论!亲测Javascript能卡浏览器Reader一辈子~
javascript·html·浏览器
清羽_ls5 小时前
React Hooks 核心规则&自定义 Hooks
前端·react.js·hooks
你的人类朋友5 小时前
“签名”这个概念是非对称加密独有的吗?
前端·后端·安全
西陵5 小时前
Nx带来极致的前端开发体验——任务缓存
前端·javascript·架构