React Mobx - 存储更改后组件未更新

IT技术 reactjs mobx mobx-react
2021-05-01 15:04:30

使用 Mobx,在更新商店(即单击按钮)后,组件不会重新渲染。我已经安装了 mobx devtools,它在初始加载后没有显示任何内容,并且控制台中没有错误。任何想法我做错了什么?

商店.js:

import { observable } from 'mobx';

class Store {

    @observable me;

    constructor() {
        this.me = 'hello';
    }

    change_me(){
        this.me = 'test 1234';

    }

}


export default Store;

布局.js:

import React from "react";
import { observer } from 'mobx-react';


@observer
export default class Layout extends React.Component{

    render(){

        return(
            <div>
                <h1>{this.props.store.me}</h1>
              <button onClick={this.on_change}>Change</button>
            </div>
        )
    }

    on_change = () => {
        this.props.store.change_me();
    }
}

索引.js:

import React from "react";
import ReactDOM from "react-dom";
import Layout from "./components/Layout";
import Store from "./Store";
import DevTools, { configureDevtool } from 'mobx-react-devtools';

// Any configurations are optional
configureDevtool({
    // Turn on logging changes button programmatically:
    logEnabled: true,
    // Turn off displaying conponents' updates button programmatically:
    updatesEnabled: false,
    // Log only changes of type `reaction`
    // (only affects top-level messages in console, not inside groups)
    logFilter: change => change.type === 'reaction',
});


const app = document.getElementById('app');
const store = new Store();

ReactDOM.render(

    <div>
        <Layout store={store} />
        <DevTools />
    </div>
, app);
3个回答

我首先将 @action 添加到您的 change_me() 函数中。据我了解,它并不总是完全必需的,但是当我忘记添加它时,我在自己的代码中多次遇到过这样的问题。

另外按照@mweststrate 的建议发布您的 .babelrc,因为它将帮助其他人检查是否加载了正确的插件。

我的猜测是未初始化的@observable。这是非常违反直觉的,但是 Babel 不能很好地处理这些。甚至添加@observable me = undefined可能会有所帮助(当你在那里分配一些东西时,请参阅生成的 js 代码。通常我会完全删除构造函数并将初始化移动到声明(即@observable me = "hello"无构造函数)。然后它应该可以正常工作。

观察 this 上下文的绑定。

<button onClick={this.on_change}>Change</button>

this 引用不会指向该类,因此当您实际单击它时,它很可能会说一些类似 no props on undefined 的内容。更改为:

  <button onClick={this.on_change.bind(this)}>Change</button>

应该修复它。或者更好的是,在构造函数中绑定上下文,这样它就不会在每次渲染时重新绑定

 constructor(props) {
   super(props)
   this.on_change = this.on_change.bind(this)
 }

然后你可以回到你的