我正在使用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 verion: 0.14.0
编辑
正如答案中指出的那样,DOM库( v0.14.0 )超出了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.
发布于 2022-06-06 20:34:03
从React 18开始,ReactDOM
应该从react-dom/client
导入,而findDOMNode
导出被认为是不推荐的,并且仍然是从react-dom
导出的。
因此:
import {findDOMNode} from 'react-dom';
import ReactDOM from 'react-dom/client';
更新:添加 documentation link
https://stackoverflow.com/questions/33031516
复制相似问题