React + Mobx: 'this' is null when trying to update store

前端 未结 3 903
傲寒
傲寒 2021-02-15 10:26

Just getting started with Mobx & React and having trouble getting the store to update. I get error when clicking the button, which should update the \'me\' property:

<
3条回答
  •  走了就别回头了
    2021-02-15 11:07

    Yes react execute event callbacks with this being null. Since you only give the onClick callback the change_me method and not the store as context.

    Solutions

    You have to set the this context yourself. you can do this in the following ways

    bad practices:

    as @Eduard said you can warp it into an arrow function. the Arrow function makes sure the this context stays the same in the function body:

     
    

    You can also use the bind method:

    
    

    this does basically the same thing.

    Why are they bad practises? on every render() call, these methods are re-created. and can result in extra unnecessary re-renders.

    Good practices

    mobx provides a action.bound which wraps the function with the proper this context:

    @mobx.action.bound
    change_me(){
        this.me = 'test 1';
    }
    

    Alternatively es6 class definition allows you to define the this context properly yourself:

    @mobx.action
    change_me = () => {
        this.me = 'test 1';
    }
    

    See the arrow function. behind the scenes: instead of defining the function/method on the prototype of the Store class. the method is created in the constructor so that the this context variable always matches the instance of the class.

    so that:

    var a = new Store(); // a.me = 'test'
    var b = new Store(); // b.me = 'test'
    a.change_me = b.change_me; // change_me function contains its own this context.
    a.change_me(); // a.me = 'test' b.me = 'test 1'
    

提交回复
热议问题