TypeError: instance.render is not a function(React)

TypeError: instance.render is not a function(React)

写了一个组件,原代码:

class App extends Component {
    
    constructor() {
        super();
        return { userInput: ''} ;
    }
 
    handleChange(e) {
        this.setState({ userInput: e.target.value });
    }
 
    clearAndFocusInput() {
        this.setState({ userInput: '' }, () => {
            this.refs.theInput.focus();
        });
    }
 
    render() {
        return (
            <div>
                <div onClick={this.clearAndFocusInput.bind(this)}>
                    Click to Focus and Reset
                </div>
                <input
                    ref="theInput"
                    value={this.state.userInput}
                    onChange={this.handleChange.bind(this)}
                />
            </div>
        );
    }
}


export  {App};

报错:TypeError: instance.render is not a function在这里插入图片描述

错误原因:constructor不能用return返回值。

需要修改constructor的代码:

class App extends Component {
    
    constructor() {
        super();
        this.state={ userInput: ''} ;
    }
 
    handleChange(e) {
        this.setState({ userInput: e.target.value });
    }
 
    clearAndFocusInput() {
        this.setState({ userInput: '' }, () => {
            this.refs.theInput.focus();
        });
    }
 
    render() {
        return (
            <div>
                <div onClick={this.clearAndFocusInput.bind(this)}>
                    Click to Focus and Reset
                </div>
                <input
                    ref="theInput"
                    value={this.state.userInput}
                    onChange={this.handleChange.bind(this)}
                />
            </div>
        );
    }
}


export  {App};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值