0
我正在使用Django和React。未捕获的不变违例:_registerComponent(...):目标容器不是DOM元素
我想显示这个HTML文件:
{% load staticfiles %}
<html>
<head>
<meta charset="utf-8">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"
integrity="sha384-0mSbJDEHialfmuBBQP6A4Qrprq5OVfW37PRR3j5ELqxss1yVqOtnepnHVP9aJ7xS"
crossorigin="anonymous">
</script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css"
rel="stylesheet" integrity="sha384-1q8mTJOASx8j1Au+a5WDVnPi2lkFfwwEAa8hDDdjZlpLegxhjVME1fgjWPGmkzs7"
crossorigin="anonymous">
<link href="{%static "css/rankingStyle.css"%}" rel="stylesheet" type="text/css"/>
<link rel="stylesheet" type="text/css" href="//fonts.googleapis.com/css?family=Raleway" />
<title>Some title</title>
</head>
<body>
<div id="app" />
<script src="{%static "public/bundle.js"%}" type="text/javascript"></script>
</body>
</html>
此文件引用js
文件:<script src="{%static "public/bundle.js"%}" type="text/javascript">
。
的js
文件已经从该阵营文件获得:
import React from 'react';
import {render} from 'react-dom';
import Criteria from './Criteria.jsx';
import { Button } from 'react-bootstrap';
var App = React.createClass({
getInitialState: function() {
return {showRest: false};
},
toggleShowRest: function() {
this.setState({showRest: !this.state.showRest});
},
render: function() {
return (
<div className="container">
<div className="text-center">
<h1> Title</h1>
<button onClick={this.toggleShowRest} type="button" className="btn btn-primary btn-circle btn-xl">Go</button>
</div>
{this.state.showRest
?
<Criteria />
:
null}
</div>
);
}
});
React.render(<App url="/api/comments"/>, document.getElementById('app'));
在浏览器中,我得到这个错误:
bundle.js:593 Uncaught Invariant Violation: _registerComponent(...): Target container is not a DOM element.
线593之前,该地区有这样的内容:
var DOMChildrenOperations = {
dangerouslyReplaceNodeWithMarkup: Danger.dangerouslyReplaceNodeWithMarkup,
到目前为止,我看了这里:Invariant Violation: _registerComponent(...): Target container is not a DOM element并尝试所有的答案。
但他们没有工作。我认为这个问题是由Django具体的东西造成的。
请张贴用'ReactDOM.render()'方法调用就行了。 顺便说一句'div'不是一个自闭的元素,你应该使用'
'。这可能会导致问题。 – pawel没有'ReactDOM.render()'方法调用。我正在使用'React.render()'。 – octavian
这是一回事,取决于React版本。你要分享吗?你有没有试过关闭div? – pawel