官术网_书友最值得收藏!

Observing the state changes

Observables alone cannot make an interesting system. We also need their counterparts, the observers. MobX gives you three different kinds of observers, each tailor-made for the use cases you will encounter in your application. The core observers are autorun, reaction, and when. We will look at each of them in more detail in the next chapter, but let's introduce autorun for now.

The autorun API takes a function as its input and executes it immediately. It also keeps track of the observables that are used inside the passed-in function. When these tracked observables change, the function is re-executed. What is really beautiful and elegant about this simple setup is that there is no extra work required to track observables and subscribe to any changes. It all just happens automatically. It's not magic, per se, but definitely an intelligent system at work, which we will cover in a later section:

import {observable, autorun} from 'mobx';

let cart = observable({
itemCount: 0,
modified: new Date()
});

autorun(() => {
console.log(`The Cart contains ${cart.itemCount} item(s).`);
});

cart.itemCount++;

// Console output:
The Cart contains 0 item(s).
The Cart contains 1 item(s).

In the preceding example, the arrow-function that was passed into autorun is executed for the first time and also when itemCount is incremented. This results in two console logs being printed. autorun makes the passed-in function (the tracking-function) an observer of the observables it references. In our case, cart.itemCount was being observed and when it was incremented, the tracking function was automatically notified, resulting in the console logs getting printed.

主站蜘蛛池模板: 黑山县| 兴业县| 珲春市| 蕲春县| 贺兰县| 临湘市| 白水县| 镶黄旗| 福安市| 株洲县| 曲水县| 沁水县| 高阳县| 孟村| 东丰县| 梅河口市| 江北区| 曲麻莱县| 灵台县| 右玉县| 门源| 湘阴县| 周宁县| 抚宁县| 和硕县| 苗栗市| 德阳市| 嘉兴市| 许昌市| 安丘市| 尼木县| 自贡市| 博爱县| 股票| 睢宁县| 土默特右旗| 镇巴县| 龙州县| 湄潭县| 云安县| 梨树县|