什么时候用ref,怎么用ref

用ref

“打在我身,疼在她心”时,用ref。比如,点击事件绑定在某个标签上,事件处理函数中却要访问另一个完全不相关的元素的真实DOM。
使用ref有以下四种方式:

  1. ref 是一个字符串。
  2. ref 是一个内联函数。
  3. ref 是一个回调函数。
  4. ref通过调用React.createRef()生成。

本例中,click事件绑定在button标签上,事件处理函数handleClick中却要访问h2元素中的内容。
在这里插入图片描述

ref是一个字符串

import React, { Component } from "react";

class MyComponent extends Component{
    state = {
        msg:"好好学习,天天向上"
    }

    handleClick = () => {
        console.log(this.refs.title);
        console.log(this.refs.title.innerText);
    }

    render(){
        const {msg} = this.state;
        const {handleClick} = this;
        return (
            <div>
                <h2 ref="title">{msg}</h2>
                <button onClick={handleClick}>点我显示消息</button>
            </div>
        )
    }
}

export default MyComponent;

ref是一个内联函数

import React, { Component } from "react";

class MyComponent extends Component{
    state = {
        msg:"好好学习,天天向上"
    }

    handleClick = () => {
        console.log(this.headerEle);
        console.log(this.headerEle.innerText);
    }

    render(){
        const {msg} = this.state;
        const {handleClick} = this;
        return (
            <div>
                <h2 ref={el => this.headerEle = el}>{msg}</h2>
                <button onClick={handleClick}>点我显示消息</button>
            </div>
        )
    }
}

export default MyComponent;

ref是一个回调函数

import React, { Component } from "react";

class MyComponent extends Component{
    state = {
        msg:"好好学习,天天向上"
    }

    handleClick = () => {
        console.log(this.headerEle);
        console.log(this.headerEle.innerText);
    }

    initHeaderEle = (el) => {
        this.headerEle = el;
    }

    render(){
        const {msg} = this.state;
        const {initHeaderEle,handleClick} = this;
        return (
            <div>
                <h2 ref={initHeaderEle}>{msg}</h2>
                <button onClick={handleClick}>点我显示消息</button>
            </div>
        )
    }
}

export default MyComponent;

ref通过调用React.createRef()生成

import React, { Component } from "react";

class MyComponent extends Component{

    state = {
        msg:"好好学习,天天向上"
    }
    
    myRef = React.createRef();

    handleClick = () => {
        console.log(this.myRef.current);
        console.log(this.myRef.current.innerText);
    }

    render(){
        const {msg} = this.state;
        const {handleClick,myRef} = this;
        return (
            <div>
                <h2 ref={myRef}>{msg}</h2>
                <button onClick={handleClick}>点我显示消息</button>
            </div>
        )
    }
}

export default MyComponent;

不用ref

“打在我身,疼在我身”时,虽然ref也可以使用,但没有必要,推荐使用event.target。比如,点击事件绑定在某个标签上,事件处理函数中需要访问本元素所在DOM。
本例中,click事件绑定在h2标签上,事件处理函数handleClick中需要访问h2自身的内容。
在这里插入图片描述

  • 用ref
import React, { Component } from "react";

class MyComponent extends Component{

    state = {
        msg:"好好学习,天天向上"
    }
    
    myRef = React.createRef();

    handleClick = () => {
        console.log(this.myRef.current);
        console.log(this.myRef.current.innerText);
    }

    render(){
        const {msg} = this.state;
        const {handleClick,myRef} = this;
        return <h2 ref={myRef} onClick={handleClick}>{msg}</h2>

    }
}

export default MyComponent;
  • 不用ref,用event.target(推荐)
import React, { Component } from "react";

class MyComponent extends Component{

    state = {
        msg:"好好学习,天天向上"
    }

    handleClick = (event) => {
        console.log(event.target);
        console.log(event.target.innerText);
    }

    render(){
        const {msg} = this.state;
        const {handleClick} = this;
        return <h2 onClick={handleClick}>{msg}</h2>

    }
}

export default MyComponent;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值