未捕获的TypeError:无法读取未定义的属性"state或props"

nix*_*get 6 ecmascript-6 reactjs es6-class

所以我开始将我的应用程序从ES2015转换为使用React的ES6.

我有一个父类和一个像这样的子类,

export default class Parent extends Component {
    constructor(props) {
        super(props);
        this.state = {
            code: ''
        };
    }

    setCodeChange(newCode) {
        this.setState({code: newCode});
    }


    login() {
        if (this.state.code == "") {
            // Some functionality
        }
    }

    render() {
        return (
            <div>
                <Child onCodeChange={this.setCodeChange} onLogin={this.login} />
            </div>
        );
    }
}
Run Code Online (Sandbox Code Playgroud)

儿童班,

export default class Child extends Component {
    constructor(props) {
        super(props);
    }

    handleCodeChange(e) {
        this.props.onCodeChange(e.target.value);
    }

    login() {
        this.props.onLogin();
    }

    render() {
        return (
            <div>
                <input name="code" onChange={this.handleCodeChange.bind(this)}/>
            </div>
            <button id="login" onClick={this.login.bind(this)}>
        );
    }
}

Child.propTypes = {
    onCodeChange: React.PropTypes.func,
    onLogin: React.PropTypes.func
};
Run Code Online (Sandbox Code Playgroud)

但是这会导致以下错误,

this.state未定义

它指的是,

if (this.state.code == "") {
    // Some functionality
}
Run Code Online (Sandbox Code Playgroud)

知道是什么原因引起的吗?

Shu*_*tri 8

您可以使用箭头功能绑定您的功能.您需要在子组件和父组件中绑定您的功能.

家长:

export default class Parent extends Component {
    constructor(props) {
        super(props);
        this.state = {
            code: ''
        };
    }

    setCodeChange = (newCode) => {
        this.setState({code: newCode});
    }


    login = () => {
        if (this.state.code == "") {
            // Some functionality
        }
    }

    render() {
        return (
            <div>
                <Child onCodeChange={this.setCodeChange} onLogin={this.login} />
            </div>
        );
    }
}
Run Code Online (Sandbox Code Playgroud)

儿童

export default class Child extends Component {
    constructor(props) {
        super(props);
    }

    handleCodeChange = (e) => {
        this.props.onCodeChange(e.target.value);
    }

    login = () => {
        this.props.onLogin();
    }

    render() {
        return (
            <div>
                <input name="code" onChange={this.handleCodeChange}/>
            </div>
            <button id="login" onClick={this.login}>
        );
    }
}

Child.propTypes = {
    onCodeChange: React.PropTypes.func,
    onLogin: React.PropTypes.func
};
Run Code Online (Sandbox Code Playgroud)

还有其他方法来绑定函数,例如您正在使用的函数,但您也需要为父组件执行此操作 <Child onCodeChange={this.setCodeChange.bind(this)} onLogin={this.login.bind(this)} />

或者您可以在构造函数中指定绑定为

家长:

constructor(props) {
    super(props);
    this.state = {
        code: ''
    };
 this.setCodeChange = this.setCodeChange.bind(this);
 this.login = this.login.bind(this);
}
Run Code Online (Sandbox Code Playgroud)

儿童

constructor(props) {
    super(props);
    this.handleCodeChange = this.handleCodeChange.bind(this);
    this.login = this.login.bind(this);
}
Run Code Online (Sandbox Code Playgroud)

  • 关于它没有什么错误**但它效率很低,因为你将在每个渲染中创建新的函数对象 (3认同)