[React] 组件对应的DOM对象

React组件内部的各生命周期方法,this指向的是当前组件的实例。

class Page extends Component {
    constructor(props){
        super(props);

        console.assert(this instanceof Page);
    }

    render() {
        console.assert(this instanceof Page);

        return (
            <span>hello world</span>
        );
    }
}

在某些情况下,需要引用组件相对应的DOM对象,这时候可以使用ref属性。

class Page extends Component {
    constructor(props) {
        super(props);
    }

    componentDidMount() {
        alert(this._dom);  //[object HTMLSpanElement]
    }

    render() {
        return (
            <span ref={span => this._dom = span}>hello world</span>
        );
    }
}

组件被挂载后,ref属性中的回调函数会立即执行,回调函数的参数就是DOM对象。
其中,this指向组件对象,我们在回调函数中,将DOM对象赋值到了组件对象的某个属性中(例如:_dom属性),
这样,我们在componentDidMount生命周期函数中,就可以通过组件的这个属性(例如:_dom属性)来访问DOM对象了。


注:
(1)ref的属性值可以不是回调函数,而是一个字符串,用来表示组件的名字,
React会在组件挂载后,把该组件对象放到this.refs的同名属性中,
然后再用ReactDOM.findDOMNode,就可以得到该组件对应的DOM对象了。

class Page extends Component {
    componentDidMount(){
        let mySpan=this.refs['mySpan'],
            mySpanDOM =ReactDOM.findDOMNode(mySpan);

        alert(mySpanDOM);  //[object HTMLSpanElement]
    }

    render() {
        return (
            <span ref="mySpan"></span>
        );
    }
}

(2)ReactDOM.findDOMNode在组件挂载后才可以使用,在constructor中使用会报错。

Uncaught Error: findDOMNode was called on an unmounted component.

参考

React: Refs and the DOM
深入React技术栈 - P38~P39

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • It's a common pattern in React to wrap a component in an ...
    jplyue阅读 3,318评论 0 2
  • react 基本概念解析 react 的组件声明周期 react 高阶组件,context, redux 等高级...
    南航阅读 1,094评论 0 1
  • 以下内容是我在学习和研究React时,对React的特性、重点和注意事项的提取、精练和总结,可以做为React特性...
    科研者阅读 8,308评论 2 21
  • 原教程内容详见精益 React 学习指南,这只是我在学习过程中的一些阅读笔记,个人觉得该教程讲解深入浅出,比目前大...
    leonaxiong阅读 2,863评论 1 18
  • 美好的一天,从早安开始。 本打算睡个懒觉,无奈,大清早被亲戚家的小孩子的吵闹声搅的不得安宁。只好放弃这个念头,起来...
    丁走心阅读 215评论 0 0