52

我正在使用 ReactJS 和 Flux 构建一个 Web 应用程序,我正在尝试使用findDOMNode方法 获取当前 div 的节点,但出现下一个错误:

Uncaught TypeError: React.findDOMNode is not a function

所以,我尝试使用getDOMNode并得到了同样的错误:

Uncaught TypeError: React.getDOMNode is not a function

我正在使用 npm 构建 JS,我使用这些方法的代码:

var React = require('react');
var stores = require('../stores');
var MessagesUserContainer = require('./messageusercontainer');
var ChatStore = stores.ChatStore;
var owner = stores.getOwner();

var MessagesList = React.createClass({

    getInitialState: function(){
        return {'muc': []};
    },
    componentDidUpdate: function(){
        var node = React.findDOMNode(this); //Error here
        node.scrollTop = node.scrollHeight;
    },
    render: function(){
        return (
                <div className="chatScroll">
                    {this.state.muc}
                </div>
            )
    }
});

module.exports = MessagesList;

ReactJS 版本:0.14.0

编辑

正如答案中所指出的,从 v0.14.0 开始的 DOM 库不在 React 核心范围内,因此我对代码进行了一些更改:

var React = require('react');
var ReactDOM = require('react-dom');
var stores = require('../stores');
var MessagesUserContainer = require('./messageusercontainer');
var ChatStore = stores.ChatStore;
var owner = stores.getOwner();

var MessagesList = React.createClass({

    getInitialState: function(){
        return {'muc': []};
    },
    componentDidUpdate: function(){
        var node = ReactDOM.findDOMNode(this);
        node.scrollTop = node.scrollHeight;
    },
    render: function(){
        return (
                <div className="chatScroll">
                    {this.state.muc}
                </div>
            )
    }
});

module.exports = MessagesList;

但我遇到了另一个问题:

Uncaught Error: Invariant Violation: findDOMNode was called on an unmounted component.
4

2 回答 2

66

在最新的 React 中更改:

ReactDOM.findDOMNode

https://facebook.github.io/react/docs/top-level-api.html#reactdom.finddomnode

它在react-dom包装中。请注意,ReactDOMServer 也已移至另一个包中。可能是在为 React 相关的平台特定 API(例如 React Native)做准备。

要导入/需要包:

import ReactDOM from "react-dom";

或者

 var ReactDOM = require('react-dom').
于 2015-10-09T06:46:16.730 回答
3

v0.14React DOM 库已从 React.js 本身移出。有一些 BC 更改,但是如果您以正确的方式编写代码,那么更改将不会很痛苦。请在此处阅读完整概述:https ://facebook.github.io/react/blog/#major-changes

于 2015-10-09T06:49:52.143 回答