我的简单组件:
var AddProductForm = React.createClass({
render: function(){
return(
<form >
<input type='text' placeholder='lablbalbalbal'/>
</form>
)
}
})
我的第二个组件,我想通过onClick“渲染”某个确定的div中的第一个组件:
var HeaderAction = React.createClass({
render: function(){
return(
<button type="button" onClick={this.handleClick} className="btn border-slate text-slate-800 btn-flat"><i className={this.props.icon + " position-left"}></i>{this.props.name}</button>
)
},
handleClick: function(){
var component = React.createElement(this.props.action.component);
ReactDOM.render( component, document.getElementById('content'));
}
})
单击“HeaderAction”组件时,会发生错误:
未捕获的不变违规:标记无效:
来自我的'组件'的console.log():
Object {$$typeof: Symbol(react.element), type: "<AddProductForm/>", key: null, ref: null, props: Object…}
$$typeof: Symbol(react.element)
_owner: null
_self: null
_source: null
_store: Object
key: null
props: Object
ref: null
type: "<AddProductForm/>"
__proto__: Object
如果在渲染调用中我为“component
”更改了“<AddProductForm/>
”,它可以正常工作,但是在渲染之前使用createElement实例化对象。
答案 0 :(得分:4)
var AddProductForm = React.createClass({
render: function(){
return(
<form >
<input type='text' placeholder='lablbalbalbal'/>
</form>
)
}
})
var HeaderAction = React.createClass({
render: function(){
return(
<button type="button" onClick={this.handleClick}</button>
)
},
handleClick: function(){
var component = React.createElement(AddProductForm);
ReactDOM.render( component, document.getElementById('content'));
}
})
var mount = document.getElementById('container');
ReactDOM.render(React.createElement(HeaderAction), mount)
我没有给你答案,但这似乎有效。我不知道你的this.props.action.component
是什么。我创造了一个小小提琴。也许我们可以解决这个问题。 https://jsfiddle.net/walkerrsmith/htaca7fa/