关于Vue访问子组件相关操作

本文介绍了Vue中如何获取和操作子组件,包括通过ref属性访问子组件的方法和属性,以及处理子组件间的交互。详细讲解了通过@click.native监听事件和事件总线(Event Bus)实现跨组件通信的方法,同时也提及了Vuex作为状态管理工具在组件通信中的应用。
摘要由CSDN通过智能技术生成

1.Vue里明确拿到某一子组件

通过传统
1.给子组件加上ref属性

<childComponent id="home" ref = "home_ref">

2.在方法中可以这么得到子组件,并调用子组件中的方法和属性

backClick() {
	console.log(this.$home_ref.message)
	this.$home_ref.scroll.scrollTo(0, 0, 500);

},

2.Vue某个子组件发生点击需要在另一个子组件进行操作

一个方法是组件二emit点击事件出来,主组件进行接受,然后ref访问组件一;
第二种更简洁的方法的是直接通过.native对组件进行监听,直接从主组件访问组件一
在这里插入图片描述
具体代码如下:

<childComponent id="home" @click.native= "backClick">

.......

backClick() {
	this.$refs.scroll.scrollTo(0, 0, 500);
	// console.log(this.$refs.scroll.message);

},

3.多层组件事件管理:事件总线

如下图,组件一中发生某事件后,需要调用组件3中的方法。
比较麻烦的办法是通过父子组件一层一层将事件传到主组件中,然后通过主组件利用ref访问组件3中的方法。
第二种方法是利用事件总线,和Vuex很像,不管理状态,管理事件监听。组件1通过this. b u s . bus. bus.emit(’’)发出事件,主组件可以通过this. b u s . bus. bus.on(’’,function)进行接受并处理。
需要注意的是,vue本来是没有 b u s 了 , 需 要 在 原 型 里 添 加 bus了,需要在原型里添加 busbus,简单来说,需要在main.js里加入以下代码

Vue.prototype.$bus = new Vue()

在这里插入图片描述

3.Vuex

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值