I just got started using React, so this is probably a very simple mistake, but here we go. My html code is very simple:
<!-- base.html --> <html>   <head>     <title>Note Cards</title>     <script src="http://<url>/react-0.11.2.js"></script> <!--     <script src="http://<url>/JSXTransformer-0.11.2.js"></script> -->     <script src="http://code.jquery.com/jquery-1.10.0.min.js"></script>     {% load staticfiles %}     <link rel="stylesheet" type="text/css" href="{% static "css/style.css" %}">     <script src="{% static "build/react.js" %}"></script>   </head>   <body>     <h1 id="content">Note Cards</h1>     <div class="gotcha"></div>   </body> </html>  Note that I am using Django's load static files here. (My JavaScript is a bit more complex, so I won't post it all here unless someone requests it.) This is the line with the error:
React.renderComponent(   CardBox({url: "/cards/?format=json", pollInterval: 2000}),   document.getElementById("content") );  After which I get the 'target container is not a DOM element error' yet it seems that document.getElementById("content") is almost certainly a DOM element.
I looked at this stackoverflow post, but it didn't seem to help in my situation.
Anyone have any idea why I'd be getting that error?
I figured it out!
After reading this blog post I realized that the placement of this line:
<script src="{% static "build/react.js" %}"></script>   was wrong. That line needs to be the last line in the <body> section, right before the </body> tag. Moving the line down solves the problem. 
My explanation for this is that react was looking for the id in between the <head> tags, instead of in the <body> tags. Because of this it couldn't find the content id, and thus it wasn't a real DOM element.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With