2016-04-11 31 views
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具体的东西造成的。

+0

请张贴用'ReactDOM.render()'方法调用就行了。 顺便说一句'div'不是一个自闭的元素,你应该使用'

'。这可能会导致问题。 – pawel

+0

没有'ReactDOM.render()'方法调用。我正在使用'React.render()'。 – octavian

+0

这是一回事,取决于React版本。你要分享吗?你有没有试过关闭div? – pawel

回答

-1

圆顶节点DIV ID后,你应该导入构建JS是应用

如:

enter image description here

相关问题