react高阶组件中,更新state时,用ref获取的实例为null

新手上路,请多包涵

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')
)
阅读 3.6k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题