�T.GYS℡ 2022-11-02 16:43 采纳率: 100%
浏览 75
已结题

如何通过全局监听事件在页面加载时自动获取子组件的数组数据

问题遇到的现象和发生背景

uniapp 子组件如何向父组件传递数组?不通过点击函数,可通过全局监听事件,在页面加载时自动获取子组件数组的数据,求例子

用代码块功能插入代码,请勿粘贴截图
<!-- 父组件 -->
<template>
    <view>
        <son @sonEven='getSonText'></son>
    </view>
</template>

<script>
    import son from '@/uni_modules/Cloud-API/components/Cloud-API/Cloud-API.vue'
    export default {
        data() {
            return {
                array: []
            }
        },
        methods: {
            getSonText(array1) {
                this.array = array1
            }
        },
        components: {
            son
        }
    }
</script>

<!-- 子组件 -->
<template>
    <view>
        <!-- 向父组件传值 -->
        <button @click="toFather">点击向父组件传值</button>
    </view>
</template>

<script>
    export default {
        data() {
            return {
                array: [1, 2, 3, 4]
            }
        },
        methods: {
            toFather() {
                this.$emit('sonEven', this.array)
            }
        }
    }
</script>


我的解答思路和尝试过的方法

全局监听事件不太清晰,不知道什么原因

我想要达到的结果

不通过点击函数,可全局监听事件在页面加载时自动获取数组

  • 写回答

5条回答 默认 最新

  • 游一游走一走 2022-11-02 17:05
    关注
    <!-- 子组件 -->
    <template>
        <view>
            <!-- 向父组件传值 -->
            <button>点击向父组件传值</button>
        </view>
    </template>
     
    <script>
        export default {
            data() {
                return {
                    array: [1, 2, 3, 4]
                }
            },
            methods: {
            }
        }
    </script>
    
    <!-- 父组件 -->
    <template>
        <view @click="test">
            <son ref="procedureEdit"></son>
        </view>
    </template>
     
    <script>
        import son from './son.vue'
        export default {
            data() {
                return {
                    array: []
                }
            },
            mounted() {
                this.array=this.$refs.procedureEdit.$data.array
            },
            methods: {
                test(){
                    console.log(this.array)
                }
            },
            components: {
                son
            }
        }
    </script>
     
     
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 11月10日
  • 已采纳回答 11月2日
  • 修改了问题 11月2日
  • 修改了问题 11月2日
  • 展开全部

悬赏问题

  • ¥15 想问一下树莓派接上显示屏后出现如图所示画面,是什么问题导致的
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号