со сложностью в больших проектах, когда много моделек, они от друг друга зависят, требуют подписки на друг друга
Если все подписывать на друг друга, то потом не размотать этот клубок
Если все делать в "умном" компоненте, в котором стоит watcher на одну модель, и он дергает action в другой модели, то у нас бизнес логика начинает жить в компонентах, что может привезти к двойному watcher-у, в итоге к зацикливанию
В общем, решено было посмотреть как там со сложностью на хабре борются и нашел такую статью https://habr.com/ru/post/353590/
Подумал, что давай ка я посмотрю примеры реакта, и разберусь как там устроено
Зашел на fluxxor.com, посмотрел примеры на гитхаб (https://github.com/BinaryMuse/fluxxor/blob/master/examples/async/app/app.jsx), и понял что компонент дергает экшн, экшн в свою очередь ходит в API, и коммитит, но коммит принадлежит не одному стору, а нескольким, то есть одновременно несколько сторов (модулей) могут слушать один коммит и обновлять себя
На Vuex это легко ложиться, так как vuex был вдохновлен Flux-ом, и понятия очень похожие
Ну вот я и накидал пример с бронированием отелей и загрузкой цен (пример максимально простой): https://github.com/BinaryMuse/fluxxor/blob/master/examples/async/app/app.jsx
Что я все же не смог решить?
Мне очень не хватает waitFor метода из Flux http://fluxxor.com/documentation/stores.html
Чтобы экшн loadMotelPrices из моего примера ждал экшн BOOKING_loadData, мне пришлось в конце экшна BOOKING_loadData вызывать его, я бы хотел переназвать экшн loadMotelPrices в BOOKING_loadData, чтобы они одновременно запускались, но перед загрузкой цен, экшн загрузки цен ждал пока закончится экшн загрузки отелей
И еще не понимаю как потом это переиспользовать, чтобы забрать один модуль стора и использовать в другом SPA Может есть уже готовые решения по такому вопросу?
Вы себе сами противоречите: - экшены должны запускаться одновременно - чтобы один работал после окончания второго Так одновременно или последовательно?)) Что плохого в явном вызове одного экшена из другого? То, что вы хотите, называется subscribeAction https://vuex.vuejs.org/api/#subscribeaction И вся его "магия" начинает играть с вами злую шутку в момент, когда вы забываете, что на некоторые экшены есть подписки.
Обсуждают сегодня