Неопределенное нарушение инварианта: целевой контейнер не является элементом DOM.- Reactjs - PullRequest
2 голосов
/ 20 сентября 2019

Этот код работает нормально при локальном запуске.Когда я загружаю это в 000webhost и использую путь bundle.js на странице WordPress, то сталкиваюсь с этой ошибкой.Я получаю вышеупомянутую ошибку без _registerComponent.Везде есть решение для ошибки с _registerComponent.

Также я получаю значение document.getElementById("app") как ноль.

app.js

import React from "../node_modules/react/index";
import { render } from "../node_modules/react-dom/index";
import Plans from "./components/Plans";
//Import CSS
import "./styles/styles.scss";

const App = () => (
      <div>
      <Plans/>
      </div>
  );
var app = document.getElementById("app");
console.log("app",document.getElementById("app"))
render(<App/>, app);
index.html

<!DOCTYPE html>
<html lang="en">
  
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div id="app"></div> 
    <script  src="./bundle.js"></script>   
</body>

</html>

    Code used in WordPress
    <html>
     <head>
        
    </head>
    <body>
    
<script src="https://unpkg.com/react@16/umd/react.development.js" crossorigin></script>
<script src="https://unpkg.com/react-dom@16/umd/react-dom.development.js" crossorigin></script>
<script async src="https://unvisitable-bows.000webhostapp.com/react-widget-subscription-plans/react-widget-subscription-plans/public/bundle.js" crossorigin></script>
    
    </body>
</html>

Ответы [ 3 ]

3 голосов
/ 20 сентября 2019

Поскольку вы не используете index.html в WordPress, вам нужно добавить корневой контейнер div для реакции, чтобы использовать для отображения вашего приложения.Попробуйте добавить div для app в WordPress HTML, т.е. <div id="app"></div>

       <html>
         <head>

        </head>
        <body>
          <div id="app"></div> 
          <script async src="https://unvisitable-bows.000webhostapp.com/react-widget-subscription-plans/react-widget-subscription-plans/public/bundle.js" crossorigin></script>

        </body>
    </html>
2 голосов
/ 20 сентября 2019

Попробуйте, в app.js

import React from 'react';
import ReactDOM from 'react-dom';
import Plans from "./components/Plans";
//Import CSS
import "./styles/styles.scss";

const App = () => (
  <div>
  <Plans/>
  </div>
 );
  ReactDOM.hydrate(
  <App />,
  document.getElementById('app')
  );
0 голосов
/ 20 сентября 2019

Ваша переменная "приложение" не определена.Попробуйте это

render(<App />, document.getElementById('app'));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...