клике на товар, он сохраняется во vuex и после перехода на другую странице, данные о товаре берутся из стора, а вот что делать если на другую странице был сделан переход не с первой страницы, а из адресной строки? вот поэтому мне нужно в computed свойствах вызвать api для подтягивания данных о товаре из api
Вся логика обрабатывается в экшене. Нет данных - запрос. Есть данные - вернуть из стейта. Не нужно городить огород. Если используешь стор для получения данных, так используй. Нафига часть в сторе, часть в компоненте делать. Запутаешься потом
У меня данные которые рендарятся в копоненте берутся из стора. Данные рендарятся из computed (использую mapState) Но может быть так,что обьект из стора может быть пустым , в этом случае мне нужно сделать как-то проверку в computed => сделать запрос API для получения обьекта, сохранить обьект в стор и снова отрендерить его в компоненте. Можэет мне не через computed это нужно делать, я вот не знаю
Эта проверка делается в экшене, написал ведь уже. И в компоненте используется не стейт, а экшен
и ещё и компонент сыпится и показывает ошибки, так как данные пустые, (property is not defined)
а экшн вызывать в Mounted() или это как-то в computed можно делать?
async mounted() { await this.$store.dispatch('Module/Action') }
Думаю что тут стоит применять другой подход. Сохранять данные не в стор, а в переменную data самого компонента. И соответственно грузить данные через апи.
в смысле передавать данные из одного компонента в другой через emit?
Всегда стоит вытягивать инфу о товаре с помощью апи при переходе на его страницу. А то что у вас на главной есть список товаров должно вытягиваться отдельным апи запросом на сервер, который выдаст список товаров с краткой инфой по каждому из них и id, по которому вы будете вытягивать полную инфу о товаре при переходе на его страницу. Тут нет необходимости складывать в стор всю вашу БД которая хранится на бэкенде чтобы ее потом показывать на других страницах. Данные о товаре в БД могут измениться и ваш стор об этом ничего не узнает
да, это конечно правильный подход, но я исхожу из того,что мне предоставили, а предоставили мне один апи со списком всех товаров(вся характеристика каждого товара в этом же апи) и могу получить ещё апи для каждого товара отдельно,в данном случае мне проще сохранить один апи со списком всех товаров, и уже при клике на каждый товар сортировать массив во vuex и доставвать оттуда товар, а не делать каждый раз новый запрос на сервер
в created() хуке на главной старнице у меня есть запрос на сервер для получения всех товаров, то есть при каждом заходе на главную страницу, список товаров во vuex перезаписывается
Обсуждают сегодня