首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Vue -将阿波罗查询结果从父组件传递到子组件

Vue -将阿波罗查询结果从父组件传递到子组件
EN

Stack Overflow用户
提问于 2019-05-07 17:45:50
回答 1查看 624关注 0票数 1

我有一个父组件,它调用阿波罗查询:

代码语言:javascript
复制
<template>
        <div class="row" style="flex-wrap: nowrap; width:102%">
            <BusinessContextTeamPanel :business_contexts="business_contexts"></BusinessContextTeamPanel></BusinessContextTeamDetailPanel>
        </div>
</template>
    <script>
        apollo: {
                    business_contexts: {
                        query: gql`query ($businessContextId: uuid!) {
                           business_contexts(where: {id: {_eq: $businessContextId }}) {
                               id
                               businessContextTeams {
                                 id
                                 team {
                                   name
                                   id
                                 }
                                 role
                               }
                           }
                         }`,
                        variables: function() {
                            return {
                                businessContextId: this.currentContextId
                            }
                        }
                    }
                },
    </script>

我的子组件( BusinessContextTeamPanel)接受输入道具并像这样使用它:

代码语言:javascript
复制
<template>
    <div v-if="business_contexts.length > 0">
        <div v-for="teams in business_contexts" :key="teams.id">
                        <div v-for="team in teams.businessContextTeams" :key="team.id" style="padding-top: 20px;min-width: 400px">
                            <div style="height: 25px; color: #83d6c0;">

                                <div style="width: 7%; font-size: 10px; float: left; padding-top: 8px; cursor: pointer;" class="fa fa-minus-circle" ></div>

                                <div style="width: 50%; float: left; padding-right: 10px;">
                                    <div class="gov-team-text" @click="editTeam(team)">{{ team.team.name }}</div>
                                </div>

                                <div style="width: auto; float: right;">
                                    <b-badge variant="light">{{ team.role }}</b-badge>
                                </div>
                                <div style="width: 45%; margin-left: 4%; float: right;">
                                </div>
                            </div>
                            <div style="clear: both; margin-bottom: 15px;"></div>
                        </div>

                    </div>
    </div>
</template>

v-if在这里抛

无法读取未定义的属性“长度”

v-for工作的时候。当我试图在子组件挂载钩子方法(loadData())中使用道具时,我也得到了undefined

代码语言:javascript
复制
<script>
    import Treeselect from '@riophae/vue-treeselect';
    import _ from "lodash";


    export default {
        name: "BusinessContextTeamPanel",
        components: { Treeselect },
        props: ['business_contexts'],
        data() {
            return {
                itemModel: {},
                allRoles: [],
                formTitle: "",
                filteredTeams: [],
                showNoTeamMsg: false
            }
        },
        mounted() {
            this.loadData();
        },
        methods: {
            loadData() {
                let roles = [];
                _.forEach(["Admin", "Contributor", "Owner", "Master", "Viewer", "User"], function (role) {
                    roles.push({id: role, label: role});
                });
                console.log(this.business_contexts); // here I get undefined
                this.allRoles = roles;
                this.showNoTeamMsg = this.business_contexts.length === 0;
            }
        }
    }
</script>

我遗漏了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-05-08 00:10:51

要么您的阿波罗查询不起作用,要么没有及时准备好子组件试图使用它。

为了调试,在父组件的模板中添加{{ business_contexts },这样您就可以看到它了。这将确认查询是否有效。

如果查询正常,则可能是您的子组件在准备就绪之前试图访问数据。将v-if更改为

代码语言:javascript
复制
<div v-if="business_contexts.length > 0">

代码语言:javascript
复制
<div v-if="business_contexts && business_contexts.length > 0">

编辑:更好的方法是,将父组件更改为根本不加载子组件,直到父组件拥有数据为止:

代码语言:javascript
复制
<BusinessContextTeamPanel v-if="business_contexts" :business_contexts="business_contexts"></BusinessContextTeamPanel></BusinessContextTeamDetailPanel>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56027960

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档