zoukankan      html  css  js  c++  java
  • react当中refs

    Refs 提供了一种方式,允许我们访问 DOM 节点  或  在 render 方法中创建的 React 元素(组件)。

    Refs主要提供了三种方式:

    import React, { Component } from 'react'
    
    import { Input } from 'antd';
    
    import Refs1 from "./refsComponents/refs1"
    
    
    //方式1:字符串字面量 (即将弃用,不推荐, 潜在bug问题)
    
    // class Refs extends Component {
    //     componentDidMount(){
    //         console.log(this.refs.zujian,this.refs.dom,this.refs.ant,"方式1");
    //     }
    
    //     render() {
    //         return (
    //             <div style={{background:"#ccc",padding:"10px"}}>
    //                 <h4>react 当中refs三种使用方式。</h4>
    
    //                 <Refs1 ref="zujian"/>
    //                 <input type="text" placeholder="请输入" ref="dom"/>
    //                 <Input placeholder="antDesign input" ref="ant"/>
    //             </div>
    //         )
    //     }
    // }
    
    //-------------------------------------------------------------------------------------------------
    
    //方式2:函数参数赋值(一般给组件实力本身)
    
    // class Refs extends Component {
    //     componentDidMount(){
    //         console.log(this.zujian,this.dom,this.ant,"方式2");
    //     }
    
    //     render() {
    //         return (
    //             <div style={{background:"#ccc",padding:"10px"}}>
    //                 <h4>react 当中refs三种使用方式。</h4>
    
    //                 <Refs1 ref={zujian=>this.zujian = zujian}/>
    //                 <input type="text" placeholder="请输入" ref={dom=>this.dom = dom}/>
    //                 <Input placeholder="antDesign input" ref={ant=>this.ant = ant}/>
    //             </div>
    //         )
    //     }
    // }
    
    //-------------------------------------------------------------------------------------------------
    
    
    //方式3:新API(createRef),官方推荐使用。
    
    class Refs extends Component {
        zujian = React.createRef()
        dom = React.createRef()
        ant = React.createRef()
    
        componentDidMount(){
            console.log(this.zujian.current,"方式3");
            console.log(this.dom.current,"方式3");
            console.log(this.ant.current,"方式3");
        }
    
        render() {
            return (
                <div style={{background:"#ccc",padding:"10px"}}>
                    <h4>react 当中refs三种使用方式。</h4>
    
                    <Refs1 ref={this.zujian}/>
                    <input type="text" placeholder="请输入" ref={this.dom}/>
                    <Input placeholder="antDesign input" ref={this.ant}/>
                </div>
            )
        }
    }
    export default Refs;

    react - 函数组件中使用refs

    import React from "react"
    import { Input } from 'antd';
    
    import Refs1 from "./refsComponents/refs1"
    
    function HooksRefs(){
        const zujian = React.useRef();
        const dom = React.useRef();
        const ant = React.useRef();
        return (
            <div style={{background:"#A6FFFF",padding:"10px"}}>
                <h4>react-Hooks 当中refs使用方式。</h4>
    
                <Refs1 ref={zujian}/>
                <input type="text" placeholder="请输入" ref={dom}/>
                <Input placeholder="antDesign input" ref={ant}/>
            </div>
        )
    }
    
    export default HooksRefs;
  • 相关阅读:
    vue 解决 打包完iE下空白
    多层josn数据 修改
    vue 初始化data中的数据
    图片查看器(缩放 拖动)
    js 懒加载
    css flex 兼容ios android--商品展示 添加购物车
    领域驱动架构(DDD)建模
    知乎复制文本
    Nlog配置文件
    未能加载文件或程序集“xxx”或它的某一个依赖项。生成此程序集的运行时比当前加载的运行时新,无法加载此程序集
  • 原文地址:https://www.cnblogs.com/swt-axios/p/14944624.html
Copyright © 2011-2022 走看看