在MyContainer
高阶组件中,使用ref获取MyComponent
的实例,但是在更新state时。proc
函数中instance
会输出两次,第一次为null值。不知道是为什么?求解答。
import React from 'react';
import ReactDOM from 'react-dom';
const MyContainer = (WrappedCompoent) => {
return class extends React.Component {
constructor (props) {
super(props)
this.state = {
name: ""
}
this.onNameChange = this.onNameChange.bind(this)
}
onNameChange (event) {
this.setState({
name: event.target.value
})
}
proc (instance) {
console.log(instance); //state更新时,会log两次,第一次为null
instance && instance.test()
}
render () {
const newProps = Object.assign({
text: "newText",
name: {
value: this.state.name,
onChange: this.onNameChange
}
}, this.props, {ref: this.proc.bind(this)})
return (
<div>
<WrappedCompoent {...newProps}/>
</div>
)
}
}
}
@MyContainer
class MyComponent extends React.Component {
test () {
console.log(123);
}
render () {
return <div>{this.props.text}<input name="name" {...this.props.name}/></div>
}
}
ReactDOM.render(
<div><MyComponent/></div>,
document.getElementById('root')
)