Использование React Router с CDN и без веб-пакета или браузера

Резюме: мне нужно запустить React Router без wepback или подобных инструментов. Прямо из ссылок CDN, но я застрял с ошибкой require.js.


Я начинаю создавать свое первое приложение с React, и я борюсь с React Router.

HTML:

<body>
    <div id="container"></div>


    <script src="https://unpkg.com/react@15/dist/react.js"></script>
    <script src="https://unpkg.com/react-dom@15/dist/react-dom.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.23/browser.js"></script>

    <script src="https://npmcdn.com/react-router@2.4.0/umd/ReactRouter.js"></script>

    <script type="text/babel" src="assets/scripts/03_templates/app.js" charset="utf-8"></script>

</body>

JS:

var { Router, Route, IndexRoute, hashHistory, IndexLink, Link, browserHistory } = ReactRouter;

//some classes 

ReactDOM.render((
    <Router history={hashHistory}>
        <Route path="/" component={Window}>
            <IndexRoute component={InitialPage}/>
            <Route path="register" component={Register} />
            <Route path="search" component={Search} />
        </Route>
    </Router>
), document.getElementById("container"));

Все работает нормально, но я получаю это на консоли:

response.js:3639 Предупреждение. Вы вручную вызываете функцию проверки React.PropTypes для getComponent поддержать IndexRoute, Это устарело и не будет работать в следующей версии. Возможно, вы видите это предупреждение из-за сторонней библиотеки PropTypes.

Итак, я полагаю, что мой реагирующий маршрутизатор - старая версия. Я изменил ссылку на

<script src="https://cdnjs.cloudflare.com/ajax/libs/react-router/4.0.0-0/react-router.js"></script> 

Предупреждение: React.createElement: тип не должен быть нулевым, неопределенным, логическим или числовым. Это должна быть строка (для элементов DOM) или ReactClass (для составных компонентов).

Я ищу об этом, и, похоже, проблема в строке 1. Поэтому я изменил это:

var { Router, Route, IndexRoute, hashHistory, IndexLink, Link, browserHistory } = ReactRouter;

К этому:

import { Router, Route, IndexRoute, hashHistory, IndexLink, Link, browserHistory } from 'react-router';

И теперь у меня есть эта проблема:

app.js: 2 Uncaught ReferenceError: требование не определено

Я искал require.js, пробовал кое-что, но ничего не решило мою проблему. Что мне не хватает? Мне нужно запустить это без веб-пакета или подобных инструментов.

Спасибо

2 ответа

Решение

Используйте это в верхней части вашего JavaScript:

var Router = ReactRouter.Router;
var Route = ReactRouter.Route;
var IndexRoute = ReactRouter.IndexRoute;
var Link = ReactRouter.Link;
var browserHistory = ReactRouter.browserHistory;

и удалите import заявления.

В настоящее время я использую этот пакет React-Router: https://unpkg.com/react-router@3.0.0/umd/ReactRouter.js

РЕДАКТИРОВАТЬ:

Вот пример на CodePen: http://codepen.io/lsmoura/pen/pNPOzp - он не использует операторы импорта.

Для прореагировать на маршрут v4.0, пожалуйста, прочтите пакет прореагировать с маршрутизатором и добавьте две ссылки js на свою страницу:

<script src="https://unpkg.com/react-router/umd/react-router.min.js"></script>
<script src="https://unpkg.com/react-router-dom/umd/react-router-dom.min.js"></script>

в коде JS вы можете использовать:

const Router = window.ReactRouterDOM.BrowserRouter;
const Route =  window.ReactRouterDOM.Route;
const Link =  window.ReactRouterDOM.Link;
const Prompt =  window.ReactRouterDOM.Prompt;
const Switch = window.ReactRouterDOM.Switch;
const Redirect = window.ReactRouterDOM.Redirect;

также можно использовать

console.log(window.ReactRouterDOM);

чтобы положить все объекты, как:

Объекты ReactRouteDOM

Вот минимальный пример того, как это можно сделать:

<!DOCTYPE html>
<html>
  <head>
    <meta charset='UTF-8'>
    <script src='https://unpkg.com/react@16.3.1/umd/react.production.min.js'></script>
    <script src='https://unpkg.com/react-dom@16.3.1/umd/react-dom.production.min.js'></script>
    <script src='https://unpkg.com/react-router@5.0.0/umd/react-router.min.js'></script>
    <script src='https://unpkg.com/react-router-dom@5.0.0/umd/react-router-dom.min.js'></script>
    <script src='https://unpkg.com/babel-standalone@6.26.0/babel.js'></script>
  </head>
  <body>
    <div id='root'></div>
    <script type='text/babel'>
      const Link = ReactRouterDOM.Link,
            Route = ReactRouterDOM.Route;

      const App = props => (
        <ReactRouterDOM.HashRouter>
          <ul>
            <li><Link to="/">TO HOME</Link></li>
            <li><Link to="/a">TO A</Link></li>
            <li><Link to="/b">TO B</Link></li>
          </ul>

          <Route path="/" exact component={Home} />
          <Route path="/a" component={A} />
          <Route path="/b" component={B} />
        </ReactRouterDOM.HashRouter>
      )

      const Home = props => <h1>HOME</h1>
      const A = props => <h1>A</h1>
      const B = props => <h1>B</h1>

      ReactDOM.render(<App />, document.querySelector('#root'));
    </script>
  </body>
</html>

Другие вопросы по тегам