Umschalten zwischen Komponenten Reagieren JS

Ich möchte erstellen Sie eine einfache Durchfluss -, mit 2-Komponenten. Die erste Komponente gerendert wird, habe ich auf eine Taste und diese Aktion machen die zweite Komponente. Klicken Sie auf die Schaltfläche aus der zweiten Komponente, es sollte, schalten Sie zurück auf die erste, sondern, ein Fehler ist aufgetreten:

Warnung: Reagieren.createElement: - Typ sollte nicht null sein, undefined,
boolean oder number. Es sollte ein string sein (für DOM-Elemente) oder eine
ReactClass (für composite-Bauteile). Überprüfen Sie die render-Methode von
exports.Warnung @ reagieren.js:20728ReactElementValidator.createElement
@ reagieren.js:9853t.die Exporte.Reagieren.createClass.render @
bundle.js:1ReactCompositeComponentMixin._renderValidatedComponentWithoutownerorcontext
@ reagieren.js:6330ReactCompositeComponentMixin._renderValidatedComponent
@ reagieren.js:6350wrapper @
reagieren.js:12868ReactCompositeComponentMixin._updateRenderedComponent @
reagieren.js:6303ReactCompositeComponentMixin._performComponentUpdate @
reagieren.js:6287ReactCompositeComponentMixin.updateComponent @
reagieren.js:6216wrapper @
reagieren.js:12868ReactCompositeComponentMixin.performUpdateIfNecessary @
reagieren.js:6164ReactReconciler.performUpdateIfNecessary @
reagieren.js:13667runBatchedUpdates @ reagieren.js:15356Mixin.führen @
reagieren.js:17245Mixin.durchführen, @ reagieren.js:17245assign.führen @
reagieren.js:15313flushBatchedUpdates @ reagieren.js:15374wrapper @
reagieren.js:12868Mixin.closeAll @ reagieren.js:17311Mixin.führen @
reagieren.js:17258ReactDefaultBatchingStrategy.batchedUpdates @
reagieren.js:8842batchedUpdates @
reagieren.js:15321ReactEventListener.dispatchEvent @ reagieren.js:10336
reagieren.js:20250

Nicht abgefangener Fehler: Invariant Violation: Element-Typ ist ungültig: erwartete
ein string (für den integrierten Komponenten) oder eine Klasse/Funktion (für composite
Komponenten) aber habe: - Objekt. Überprüfen Sie die render-Methode von
exports.invariante @ reagieren.js:20250instantiateReactComponent @
reagieren.js:18268ReactCompositeComponentMixin._updateRenderedComponent @
reagieren.js:6312ReactCompositeComponentMixin._performComponentUpdate @
reagieren.js:6287ReactCompositeComponentMixin.updateComponent @
reagieren.js:6216wrapper @
reagieren.js:12868ReactCompositeComponentMixin.performUpdateIfNecessary @
reagieren.js:6164ReactReconciler.performUpdateIfNecessary @
reagieren.js:13667runBatchedUpdates @ reagieren.js:15356Mixin.führen @
reagieren.js:17245Mixin.durchführen, @ reagieren.js:17245assign.führen @
reagieren.js:15313flushBatchedUpdates @ reagieren.js:15374wrapper @
reagieren.js:12868Mixin.closeAll @ reagieren.js:17311Mixin.führen @
reagieren.js:17258ReactDefaultBatchingStrategy.batchedUpdates @
reagieren.js:8842batchedUpdates @
reagieren.js:15321ReactEventListener.dispatchEvent @ reagieren.js:10336

Erste Komponente:

/** @jsx React.DOM */

var Second = require('components/second/view.jsx');

module.exports = React.createClass({

handlerClick: function () {
    ReactDOM.render(
        <Second />,
        document.getElementById("app-container")
    )
},

render: function() {
  return (
    <input type="button" value="COMPONENT 1" onClick={this.handlerClick} />
  )
}
});

Zweite Komponente:

/** @jsx React.DOM */

var First = require('components/first/view.jsx');

module.exports = React.createClass({

handlerClick: function () {
    ReactDOM.render(
        <First />,
        document.getElementById("app-container")
    )
},

render: function() {
  return (
    <input type="button" value="COMPONENT 2" onClick={this.handlerClick} />
  )
}
});

Index.js

ReactDOM.render(
    <div>
        <First />
    </div>,
    document.getElementById("app-container")
);
keine Notwendigkeit, fügen Sie die ganze Fehlermeldung angezeigt, und Sie können auch reinigen Sie Ihre Frage konkreter sein, sonst kann niemand helfen.

InformationsquelleAutor user5512965 | 2015-12-03

Schreibe einen Kommentar