Задать вопрос
valexeich
@valexeich

Props не успевает получать данные из родительского компонента, как исправить?

Я загружаю асинхронно данные в родительском компоненте, и передаю props в дочерний, но он undefined потому-что не успевает получить данные, как это исправить?

Родительский компонетн:

<template>
    <div class="main">
        <TheHeader :user="room.user"/>
        <!-- <div class="container-main"> -->
                <!-- <div class="default-text">
                <h4>Select chat to start messaging</h4>
            </div> -->
            <!-- <main class="messages"> -->
                
            <!-- </main>
            <message-input/>
        </div> -->
    </div>
</template>

<script>
import TheMessageInput from './UI/TheMessageInput.vue';
import TheHeader from './TheHeader.vue'

export default {
    components: {
        TheMessageInput,
        TheHeader
    },
    data() {
        return {
            room: {}
        }
    },
    methods: {
        async getRoom() {
            this.room = await this.$store.dispatch('chat/getRoom', this.$route.params.id);
        }
    },
    async mounted() {
        await this.getRoom();
    }
}
</script>


Дочерний компонент:

<template>
    <div class="header">
        <div class="container">
            <div class="chat-info">
                <img src="https://c4.wallpaperflare.com/wallpaper/471/317/70/chainsaw-man-scars-red-eyes-looking-at-viewer-yoru-hd-wallpaper-preview.jpg" alt="avatar">
                <!-- <img :src="`http://localhost:8000/${user.avatar}.png`" alt="avatar"> -->
                <div class="user-info">
                    <p class="user-username">john</p>
                    <p class="user-status">online</p>
                </div>
            </div>
            <div class="actions">
                <i class="bi bi-search"></i>
            </div>
        </div>
    </div>
</template>

<script>
export default {
    props: {
        user: {
            type: Object,
            required: true
        }
    },
    mounted() {
        console.log(this.user)
    }
}
</script>
  • Вопрос задан
  • 97 просмотров
Подписаться 1 Простой 3 комментария
Пригласить эксперта
Ответы на вопрос 1
@tixxxxon
Я стараюсь быть веб-разработчиком
Добавь watch на пропс, и всё
Ну и лучше в room определить ключ user, хотя бы как null
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы