vue 如何处理两个组件异步问题_详解vue2父组件传递props异步数据到子组件的问题...

本文探讨了在Vue2中处理组件间异步数据传递的问题,特别是父组件向子组件传递异步获取的数据。通过案例分析了使用props、v-if、watch、computed、Vuex等多种解决方案,强调了异步数据初始为空导致的问题及其规避方法,旨在帮助开发者更好地理解和处理Vue应用中的异步数据更新问题。
摘要由CSDN通过智能技术生成

测试环境:vue v2.3.3, vue v2.3.1

案例一

父组件parent.vue

// asyncData为异步获取的数据,想传递给子组件使用

父组件

import child from './child'

export default {

data: () => ({

asyncData: ''

}),

components: {

child

},

created () {

},

mounted () {

// setTimeout模拟异步数据

setTimeout(() => {

this.asyncData = 'async data'

console.log('parent finish')

}, 2000)

}

}

子组件child.vue

子组件{ {childData}}

export default {

props: ['childData'],

data: () => ({

}),

created () {

console.log(this.childData) // 空值

},

methods: {

}

}

上面按照这里的解析,子组件的html中的{ {childData}}的值会随着父组件的值而改变,但是created里面的却不会发生改变(生命周期问题)

案例二

parent.vue

父组件

import child from './child'

export default {

data: () => ({

asyncObject: ''

}),

components: {

child

},

created () {

},

mounted () {

// setTimeout模拟异步数据

setTimeout(() => {

this.asyncObject = {'items': [1, 2, 3]}

console.log('parent finish')

}, 2000)

}

}

child.vue

子组件

{ {childObject.items[0]}}

export default {

props: ['childObject'],

data: () => ({

}),

created () {

console.log(this.childObject) // 空值

},

methods: {

}

}

created里面的却不会发生改变, 子组件的html中的{ { {childObject.items[0]}}的值虽然会随着父组件的值而改变,但是过程中会报错

// 首先传过来的是空,然后在异步刷新值,也开始时候childObject.items[0]等同于''.item[0]这样的操作,所以就会报下面的错

vue.esm.js?8910:434 [Vue warn]: Error in render function: "TypeError: Cannot read property '0' of undefined"

针对二的解决方法:

使用v-if可以解决报错问题,和created为空问题

// parent.vue

父组件

import child from './child'

export default {

data: () => ({

asyncObject: '',

flag: false

}),

components: {

child

},

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值