Извините, если это действительно очевидно, но я новичок в Vue и могу использовать некоторую помощь.
Я собираю массив данных (сообщений) из своего магазина и пытаюсь просто сохранить консольный журнал один из объектов в массиве, но он показывает неопределенный каждый раз. Если я консольный журнал весь массив, он возвращает нормально.
Я предполагаю, что это как-то связано с данными, которые не загружаются до console.log в созданном хуке? Я перепробовал все, что мог, и это сводило меня с ума. Любая помощь приветствуется (упрощенный код ниже).
<script>
export default {
components: {},
computed: {
posts() {
return this.$store.state.posts;
}
},
created() {
this.$store.dispatch("getPosts");
console.log(this.posts[0])
},
};
</script>
//Store code Below
export const state = () => ({
posts: [],
})
export const mutations = {
updatePosts: (state, posts) => {
state.posts = posts
}
}
export const actions = {
async getPosts({
state,
commit,
dispatch
}) {
if (state.posts.length) return
try {
let posts = await fetch(
`${siteURL}/wp-json/wp/v2/video`
).then(res => res.json())
posts = posts
.filter(el => el.status === "publish")
.map(({
acf,
id,
slug,
video_embed,
title,
date,
content
}) => ({
acf,
id,
slug,
video_embed,
title,
date,
content
}))
commit("updatePosts", posts)
} catch (err) {
console.log(err)
}
}
}