react Refs简单总结

8 篇文章 0 订阅
4 篇文章 1 订阅

2 Refs 转发

Ref 转发是一项将 ref 自动地通过组件传递到其一子组件的技巧。对于大多数应用中的组件来说,这通常不是必需的。但其对某些组件,尤其是可重用的组件库是很有用的。最常见的案例如下所述。一般情况是用不到Refs这个东西,因为我们并不直接操作底层DOM元素,而是在render函数里去编写我们的页面结构,由React来组织DOM元素的更新

1 为什么用到refs

简单的来说就是处理DOM元素的focus,文本的选择或者媒体的播放等,以及处罚强制动画或者同第三方DOM库集成的时候。

2 HTML elements

    export default class StrContext  extends  React.Component{
    static contextType = Tree
    constructor(props) {
        super();
        this.state = {
            myRef: React.createRef()
        }
    }
    componentDidMount(){
       console.log(this.state.myRef.current)
    }
    render() {
        return (
            <div ref={this.state.myRef}>
                {this.context}
            </div>
        )
    }
}

3 Class Components

str.js

import React from 'react'
import StrContext from '../../components/StrContext/strContext'
export default class Str extends React.Component{
    constructor(props) {
        super();
        this.state = {
            ref : React.createRef()
        }
    }
    componentDidMount() {
        this.state.ref.current.getName()
    }
render() {
    return(
        <div>
            <button onClick={this.props.setState}>点击确认</button>
            <StrContext ref={this.state.ref}></StrContext>
        </div>
    )
}

}

strContext.js

import React from 'react'
import {Tree} from "../../context/context";
export default class StrContext  extends  React.Component{
    static contextType = Tree
    constructor(props) {
        super();
        this.state = {
        }
    }
    getName(){
        console.log("测试数据")
    }
    render() {
        return (
            <div>
                {this.context}
            </div>
        )
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值