вызвать makeObservable/makeAutoObservable чтобы этот реактивно использовать поля этого класса в компонентах, к которым подключен этот стор, в то время как для компонента-класса достаточно просто указать @observable value = ‘foo’ и в рендере уже реактивно будет использоваться это поле? Почему нет необходимости для самих компонентов-классов в конструкторах использовать makeObservable(this)?
Отвечаю сам себе, исходя из документации, «The observer HoC automatically subscribes React components to any observables that are used during rendering» то есть компонент, «помеченный» декоратором observer будет обращать внимание на то какие obserable были задействованы в процессе выполнения render и неважно откуда они — из поля этого же класса или из стороннего стора. Поэтому для того чтобы сделать сторонний стор «подписываемым», необходимо вызвать make(Auto)Observable на его this, а если необходимо подписаться, то мы не должны делать сам класс observable через makeObservable, а достаточно просто указать что тот или иной observable нужен в render. Так mobx решает проблему оптимизации и исключает ненужные re-renders.
Обсуждают сегодня