zoukankan      html  css  js  c++  java
  • react开发教程(六)React与DOM

    ReactDOM

    findeDOMNode

    语法:DOMElement findDOMNode(ReactComponent component)
    描述:获取改组件实例相对应的DOM节点 案例:

    import React, { Component } from 'react';
    import ReactDOM from 'react-dom';
    
    class App extends Component {
        componentDidMount() {
            const dom = ReactDOM.findDOMNode(this)
        }
        
        render() {}
    }
    

    render

    语法:

    ReactComponent render(
        ReactElement element,
        DOMElement container,
        [function callback]
    )

    描述:改方法吧元素挂载到container中,并且返回element的实例(即refs的引用)。当组件装载完毕时,callback就会被调用。

    import React, { Component } from 'react';
    import ReactDOM from 'react-dom';
    
    class App extends Component {
        componentDidMount() {
            const dom = ReactDOM.findDOMNode(this)
        }
        
        render() {}
    }
    

    unstable_renderSubtreeIntoContainer

    语法:

    ReactComponent unstable_renderSubtreeIntoContainer(
          parentComponent component,
        ReactElement element,
        DOMElement container,
        [function callback]
    )

    描述:更新组件到传入的DOM节点上,可以使用它完成在组件内部实现跨组件的DOM操作

    import React, { Component } from 'react';
    import ReactDOM from 'react-dom';
    
    class App extends Component {
        componentDidMount() {
            const dom = ReactDOM.findDOMNode(this)
        }
        
        render() {}
    }
    

    refs

    它是react组件中非常特殊的prop,可以附加到任何一个组件上,组件调用是会新建一个该组件的实例,而refs就会指向这个实例。
    它可以是一个回调函数,这个回调函数会在组件被挂载后立即执行。

    <input type="text" ref={(ref)=>this.textInput = ref} />
    

    也可以是一个字符串

    <Comp ref="myComp"/>
    

    吧refs放到原生的DOM组件中,我们可以通过refs获取到DOM节点;而如果吧refs放到React组件上获取到的就是组件的实例

    上一篇:react开发教程(五)生命周期

    下一篇:react开发教程(七)React事件系统

  • 相关阅读:
    Ubuntu操作系统如何设置默认启动内核
    设置和取消环境变量
    vue create与vue init的区别
    base64 编解码
    获取url中的参数
    ubuntu账户密码正确但是登录不了怎么办
    斐波那契数列的递推式-----动态规划
    Round-Robin轮询调度法及其实现原理
    MySql中float类型的字段的查询
    使用 Python 从网页中提取主要文本内容
  • 原文地址:https://www.cnblogs.com/10manongit/p/12870448.html
Copyright © 2011-2022 走看看