返回顶部
首页 > 资讯 > 前端开发 > JavaScript >React中的Refs属性你来了解吗
  • 176
分享到

React中的Refs属性你来了解吗

2024-04-02 19:04:59 176人浏览 安东尼
摘要

目录1 介绍2 使用方法2.1 createRef(版本>=React16.3)2.2 回调Refs2.3 String类型的Refs(已过时,不推荐使用)2.4 useRef

1 介绍

react组件的三大属性:

1.props属性:封装传递给组件的参数

2.state属性:组件的状态,当值发生改变后,重新渲染组件

3.refs属性:

(1)通过该属性可以去访问DOM元素或render函数中的react元素(虚拟的DOM元素) ——DOM元素或render函数中的react元素的代理(句柄)

(2)本质是ReactDOM.render()函数返回的实例(组件实例或DOM节点)

Refs在计算机中称为弹性文件系统。React中的Refs提供了一种方式,允许我们访问DOM节点或在render方法中创建的React元素。本质为ReactDOM.render()返回的组件实例,如果是渲染组件则返回的是组件实例,如果渲染dom则返回的是具体的dom节点。

作用:Refs时React提供给我们安全访问DOM元素或者某个组件实例的句柄。在类组件中,React将ref属性中第一个参数作为DOM中的句柄。在函数组件中,React用hooks的api useRef也能获得ref。

2 使用方法

2.1 createRef(版本>=React16.3)

一般在构造函数中将refs分配给实例属性,以供组件的其他方法中使用。

1、对于html元素:可以获取元素实例

示例代码:

class Refs extends React.Component {
    constructor(props) {
        super(props);
        // 在构造函数中初始化一个ref,然后在return中就可以使用了
        this.myRef = React.createRef();
        console.log(this.myRef);
    }
    componentDidMount() { // 在render()函数执行完成后调用
        this.myRef.current.innerHTML = "橘猫吃不胖"; // this.myRef中有一个current属性
    }
    render() {
        return (
            <div>
                {}
                <div ref={this.myRef}></div>
            </div>
        );
    }
}

在这里插入图片描述

2、可以和类组件进行绑定 —— 代表类组件的实例

示例代码:

class Refs extends React.Component {
    constructor(props) {
        super(props);
        this.myRef = React.createRef();
    }
    componentDidMount() {
        // 在父组件中调用了子组件的方法
        this.myRef.current.change();
    }
    render() {
        return <Children ref={this.myRef}/>
    }
}

class Children extends React.Component {
    change() {
        console.log("橘猫吃不胖变身");
    }
    render() {
        return <span>橘猫吃不胖</span>
    }
}

2.2 回调Refs

React将在组件挂载时,会调用ref回调函数并传入DOM怨怒是,当卸载时调用它并传入null。早componentDidMount或componentDidUpdate触发前,React会保证refs一定是最新的。

示例代码:

class Refs extends React.Component {
    constructor(props) {
        super(props);
        this.targetRef = null;
        this.myRef = (e) => this.targetRef = e;
    }
    componentDidMount() {
        console.log("this.refs" + this.refs.container);
    }
    render() {
        return <div ref={this.myRef}>
            橘猫吃不胖
        </div>
    }
}

2.3 String类型的Refs(已过时,不推荐使用)

示例代码:

class Refs extends React.Component {
    constructor(props) {
        super(props);
        this.targetRef = null;
        this.myRef = (e) => this.targetRef = e;
    }
    componentDidMount() {
        console.log("this.refs" + this.refs.container);
    }
    render() {
        return <div ref={this.myRef}>
            橘猫吃不胖
        </div>
    }
}

2.4 useRef(React Hooks)

function HookRef(props) {
    const inputElement = useRef();
    return (
        <div>
            <input ref={inputElement}/>
            <button onClick={() => {
                inputElement.current.focus()
            }}>获得焦点
            </button>
        </div>
    )
}

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!    

--结束END--

本文标题: React中的Refs属性你来了解吗

本文链接: https://lsjlt.com/news/141938.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • React中的Refs属性你来了解吗
    目录1 介绍2 使用方法2.1 createRef(版本>=React16.3)2.2 回调Refs2.3 String类型的Refs(已过时,不推荐使用)2.4 useRef...
    99+
    2024-04-02
  • React中的Refs属性怎么用
    这篇“React中的Refs属性怎么用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React中的Refs属性怎么用”文章吧...
    99+
    2023-06-29
  • React三大属性之Refs的使用详解
    目录类组件 函数组件面试常问:React中的refs作用是什么? refs是React中用来取得某个JSX组件或者某个DOM中的一些状态值的时候,用来获取节点的方法。在React官方...
    99+
    2024-04-02
  • Vue的computed计算属性你了解吗
    目录computed计算属性1、什么是计算属性2、为什么要用计算属性3、compute、methods和watch三者的区别4、案例:遍历数组对象的时候进行监视总结computed计...
    99+
    2024-04-02
  • react中的axios模块你了解吗
    目录一、react中axios模块的使用1、基于Promise的HTTP库用在浏览器和node.js中2、创建XMLHttpRequest对象:3、在react中安装axios4、发...
    99+
    2024-04-02
  • React中的Diff算法你了解吗
    目录一、Diff算法的作用二、React的Diff算法  1、什么是调和?2、什么是React diff算法?3、diff策略4、tree diff:5、comp...
    99+
    2024-04-02
  • React的三大属性你都知道吗
    目录React三大属性props函数组件类组件state有状态组件和无状态组件setStateprops和state属性的区别refsReact.createRefref的绑定总结R...
    99+
    2024-04-02
  • jQuery的操作属性你真的了解吗
    目录一、操作属性1、读取属性值:attr(属性名)2、修改属性值(1)attr(key,value)(2)attr(key,fn)(3)attr({属性名1:属性值,属性名2:属性值...
    99+
    2024-04-02
  • react中的双向绑定你真的了解吗
    前言:因为项目原因需要学习另一个超级火的框架react, 因为之前一直使用vue进行开发,所以在学习react中会不自觉的代入一些vue中的概念来理解react中的实现,下面就通过对...
    99+
    2024-04-02
  • React的事件处理你了解吗
    目录一、React的事件处理1、与DOM事件处理的不同之处(1)React事件的命名方式:小驼峰方式,DOM的命名方式是小写(2)事件处理函数是以对象的方式赋值,而不是以字符串的方式...
    99+
    2024-04-02
  • C++的继承特性你了解吗
    目录导语:继承作用继承的结果继承方式子类构造赋值兼容规则/向上转换/内存切片多继承虚拟继承总结导语: C++是对C语言的优化和改进,C++之所以优秀的点在于它的特性:抽象、封装、继承...
    99+
    2024-04-02
  • C语言中的柔性数组你了解吗
    目录1.什么是柔性数组2.柔性数组应该如何使用3.柔性数组的替代方案及内存分布对比4.柔性数组有哪些优点总结1.什么是柔性数组 柔性数组就是大小可以变化的数组。 注意跟C99中的变长...
    99+
    2023-05-15
    C语言柔性数组使用 C语言 柔性数组 C语言 数组
  • 一起来了解React的Hook
    目录StateHook声明多个state变量那么,什么是HookEffectHookHook使用规则自定义Hook其他Hook总结State Hook 这个例子用来显示一个计数器。当...
    99+
    2024-04-02
  • STL中的string你了解吗
    目录模拟实现一个string类成员变量构造函数遍历与容量相关的成员函数运算符的重载修改器常用的几个字符串函数总结STL(standard template libaray-标准模板库...
    99+
    2024-04-02
  • redis中的bitmap你了解吗
    目录1、BitMap是什么2、setbit命令介绍 总结1、BitMap是什么 通过一个bit位来表示某个元素对应的值或者状态,其中的key就是对应元素本身。我们知道8个b...
    99+
    2024-04-02
  • C++inline函数的特性你了解吗
    目录一.inline的作用(内联函数)二.inline的实现(注意debug模式下内联函数不会展开)三.使用inline的注意事项四.inline和预处理的区别总结一.inline的...
    99+
    2024-04-02
  • 你必须了解的JavaScript中的属性描述对象详解(上)
    目录属性描述对象Object.getOwnPropertyDescriptor()Object.getOwnPropertyNames()Object.defineProperty(...
    99+
    2022-12-22
    JavaScript属性描述对象 JavaScript属性描述 JavaScript属性
  • 你必须了解的JavaScript中的属性描述对象详解(下)
    目录元属性valuewritableenumerableconfigurable存取器对象的拷贝控制对象状态Object.preventExtensions()Object.isEx...
    99+
    2022-12-22
    JavaScript属性描述对象 JavaScript属性描述 JavaScript属性
  • C语言中的柔性数组你真的了解吗
    目录柔性数组概念:特点:与指针动态开辟的比较指针动态开辟柔性数组指针动态开辟的缺点总结柔性数组概念: 柔性数组就是一种特殊的数组 它也是结构体最后一个成员 也就是说,它存在结构体最后...
    99+
    2024-04-02
  • 你了解PHP中的数据类型吗?一起来学习!
    PHP是一种广泛应用于Web开发的编程语言,它支持多种数据类型。在使用PHP进行开发时,了解和正确使用不同的数据类型是非常重要的。本文将详细介绍PHP中的数据类型,并提供一些演示代码。 布尔型(Boolean) 布尔型表示两个状态:tr...
    99+
    2023-07-09
    数据类型 学习笔记 http
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作