vue 子级拿值_vue 父组件通过$refs获取子组件的值和方法详解

本文介绍了在Vue项目中,父组件如何直接通过$refs调用子组件的数据和方法,包括如何定义子组件的data和methods,并在父组件中进行调用,同时提醒注意$refs在初始渲染时不可用的特性。
摘要由CSDN通过智能技术生成

前言

在vue项目中组件之间的通讯是很常见的问题,同时也是很重要的问题,我们大致可以将其分为三种情况:

父传子:在父组件中绑定值,在子组件中用props接收

子传父:在父组件中监听一个事件,在子组件中利用$emit触发这个事件并带上数据作为第二个参数,这时父组件中监听事件的回调函数就会被调用,回调函数的参数就是子组件带上来的数据,这样就可以在父组件中使用子组件的数据了,

兄弟之间的传递:我们可以使用事件总线(eventBus)来轻松的解决,其实就是发布订阅者模式

今天我们要看的是父组件如何直接调取子组件的数据和方法,而不是通过子组件传上来的

在这里我们要理解父组件直接拿事件是在父组件上,子组件传上来数据,事件是在子组件上,是完全不同的两种情况

代码展示

子组件 children.vue,我们在子组件中定义了数据sonData和方法sonMethod

// children.vue

我是 children

export default {

data: () => ({

sonData: '我是子组件的数据!'

}),

methods: {

sonMethod() {

console.log('我是子组件的方法!')

}

},

computed: {

},

created() {

}

}

父组件 文件

// 父组件

父组件

import children from './coms/children'

export default {

data() {

return {}

},

components: {

children

},

methods: {

onclick() {

// 或者 let chil = this.$refs['ch']

let chil = this.$refs.ch

// 父组件可以通过$refs拿到子组件的对象

// 然后直接调用子组件的 methods里的方法和data里的数据

console.log(chil) //子组件对象

console.log(chil.sonData) // 我是子组件的数据

console.log(chil.sonMethod()) // 我是子组件的方法

}

}

}

注意事项

因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!,所以它不是响应式的,不能用在模板或者计算属性中。

以上这篇vue 父组件通过$refs获取子组件的值和方法详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

时间: 2019-11-06

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值