React 中 this指向问题

作者: Fortune_Cookie | 来源:发表于2018-12-13 15:46 被阅读0次

    在写react mobx的demo时,给checkbox 添加一个onChange事件,并且忘记在constructorbind事件,导致this指向错误

    import React from 'react'
    import { observer } from 'mobx-react'
    
    @observer
    class Todo extends React.Component {
        constructor(props){
            super(props);
        // this.toggleFinished = this.toggleFinished.bind(this)
        // this.removeTodo = this.removeTodo.bind(this)
    }
    
    toggleFinished() {
        console.log(this)    // undefined,因为并没有绑定this
        const todo = this.props.todo;
        todo.finished = !todo.finished
    }
    removeTodo = () => {
        const i = this.props.i;
        // const AppState = this.props.AppState;
        this.props.AppState.todoList.splice(i,1)
    }
    
    render(){
        const todo = this.props.todo;
        return (
            <li>
                <input type="checkbox" checked={todo.finished} onChange={this.toggleFinished} />
                id:{todo.id},task:{todo.task},finished:{todo.finished?'true':'false'}
                <button onClick={this.removeTodo}>remove it</button>
            </li>
        )
    }
    }
    
    export default Todo
    
    image.png

    报错原因: this并没有绑定到Todo
    官方文档React处理事件中这么解释:在JSX回调中你必须注意 this 的指向。 在 JavaScript 中,类方法默认没有 绑定 的。如果你忘记绑定 this.handleClick 并将其传递给onClick,那么在直接调用该函数时,this 会是 undefined


    解决方法:
    1.在constructor中绑定this

    constructor(props){
        super(props);
        this.toggleFinished = this.toggleFinished.bind(this)  //  将this绑定到当前对象
        // this.removeTodo = this.removeTodo.bind(this)
    }
    

    2.使用箭头函数 ()=>

    toggleFinished =() =>{
        console.log(this) // Todo...
        // const todo = this.props.todo;
        // todo.finished = !todo.finished
    }
    

    箭头函数() this指向

    MDN解释:在箭头函数中,this与封闭词法上下文的this保持一致。在全局代码中,它将被设置为全局对象。
    在本章中,也就是this指向外层调用者 Todo

    相关文章

      网友评论

        本文标题:React 中 this指向问题

        本文链接:https://www.haomeiwen.com/subject/vacbhqtx.html