• 周五. 2月 23rd, 2024

5G编程聚合网

5G时代下一个聚合的编程学习网

热门标签

react用ref之坑 (react中findDOMNode)

admin

11月 28, 2021

今天在开发的时候自定义的组件一直选不中元素,查了许久,终于弄明白了

看到了项目中的findDomNode查了一下,如下:

import { findDomNode } from ‘react-dom’;

简单来说是用来得到实际Dom的,因为react组件有个特点,它有自定义组件,比如<Ant_Table />这种,用ref来获取这种组件获取到的这是组件定义的对象的实例,见下面代码

getNodeInstance() {
    const tableDom = findDOMNode(this.table.current) as Element
}   
function WapShop() {
    return (
        <div>
              <Ant_Table ref={this.table} />
        </div>
    );
}

这里的tableDom就是一个Ant_Table的实例,但是如果这样: 
 此时initailNode会得到Ant_Table组件中render方法返回的dom元素。
let initialNode = findDomNode(this.refs.table);
reactJs对DOM的操作

  1. 使用选择器
    var Btn = document.getElementById(‘btn’)
    ReactDom.findDOMNode(Btn).style.color = ‘red’

  2. 使用ref
    在标签内使用ref=’btn’

this.refs.btn.style.color = ‘red’
Refs 是访问到组件内部DOM节点唯一可靠的方法

注意:不要在render或render之前对Refs进行调用

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注