打造全能开发者,开启技术无限可能

vue同级组件传值

时间:2024-12-23

分类:前端开发

编辑:admin

在Vue中,同级组件之间的传值能够经过事情总线(EventBus)或许Vuex来完成。以下是一个简略的示例,演示怎么运用事情总线在同级组件之间传递数据。首要,...

在Vue中,同级组件之间的传值能够经过事情总线(Event Bus)或许Vuex来完成。以下是一个简略的示例,演示怎么运用事情总线在同级组件之间传递数据。

首要,创立一个事情总线目标:

```javascript// eventbus.jsimport Vue from 'vue';export const EventBus = new Vue;```

在一个组件中发送事情:

```javascript// SenderComponent.vue Send Message

import { EventBus } from './eventbus.js';

export default { methods: { sendMessage { EventBus.$emit; } }}```

在另一个组件中监听事情:

```javascript// ReceiverComponent.vue {{ message }}

import { EventBus } from './eventbus.js';

export default { data { return { message: '' }; }, created { EventBus.$on => { this.message = message; }qwe2; }, beforeDestroy { EventBus.$off; }}```

在这个示例中,`SenderComponent` 在按钮点击时经过事情总线发送一个音讯。`ReceiverComponent` 在创立时监听这个事情,并在接纳到音讯时更新其数据特点。记住在组件毁掉前移除事情监听,以防止内存走漏。

这种办法适用于简略的场景。关于更杂乱的运用,主张运用Vuex来办理状况,它供给了更强壮的状况办理和组件通讯才能。

Vue同级组件传值详解

在Vue.js的开发过程中,组件之间的通讯是必不可少的。除了父子组件之间的通讯,同级组件之间的传值也是常见的需求。本文将具体介绍Vue同级组件传值的几种办法,协助开发者更好地了解和运用这些技巧。

一、事情总线(Event Bus)

事情总线是一种简略且常用的办法,用于完成Vue同级组件之间的通讯。它经过创立一个空的Vue实例作为中心事情总线,然后在组件内部运用`$emit`和`$on`办法来触发和监听事情。

1. 创立事情总线

首要,咱们需求创立一个事情总线实例:

```javascript

// event-bus.js

import Vue from 'vue';

export const EventBus = new Vue();

2. 触发事情

在需求触发事情的组件中,运用`$emit`办法来发送事情:

```javascript

// ChildComponent.vue

export default {

methods: {

sendEvent() {

EventBus.$emit('customEvent', 'Hello from Child!');

}

3. 监听事情

在需求接纳事情的组件中,运用`$on`办法来监听事情:

```javascript

// ParentComponent.vue

export default {

mounted() {

EventBus.$on('customEvent', (data) => {

console.log(data); // Hello from Child!

});

},

beforeDestroy() {

EventBus.$off('customEvent'); // 组件毁掉前撤销监听

二、Vuex

Vuex是一个专为Vue.js运用程序开发的状况办理模式。它选用集中式存储办理一切组件的状况,并以相应的规矩确保状况以一种可猜测的办法发生变化。运用Vuex能够完成同级组件之间的状况同享。

1. 装置Vuex

首要,你需求装置Vuex:

```bash

npm install vuex --save

2. 创立Vuex实例

创立一个Vuex实例,并在Vue实例中注入它:

```javascript

// store.js

import Vue from 'vue';

import Vuex from 'vuex';

Vue.use(Vuex);

export default new Vuex.Store({

state: {

message: 'Hello from Vuex!'

},

mutations: {

updateMessage(state, payload) {

state.message = payload;

}

// main.js

import Vue from 'vue';

import App from './App.vue';

import store from './store';

new Vue({

store,

render: h => h(App)

}).$mount('app');

3. 同级组件拜访Vuex状况

在同级组件中,你能够经过`this.$store.state`来拜访Vuex状况:

```javascript

// ParentComponent.vue

export default {

computed: {

message() {

return this.$store.state.message;

}

4. 同级组件修正Vuex状况

在同级组件中,你能够经过`this.$store.commit`来修正Vuex状况:

```javascript

// ChildComponent.vue

export default {

methods: {

updateMessage() {

this.$store.commit('updateMessage', 'Hello from Child!');

}

三、$refs

`$refs`是Vue实例的一个特点,它答应你直接拜访DOM元素或子组件实例。经过运用`$refs`,你能够完成同级组件之间的直接通讯。

1. 引证子组件

在父组件中,运用`ref`特点来引证子组件:

```javascript

// ParentComponent.vue

本站部分内容含有专业性知识,仅供参考所用。如您有相关需求,请咨询相关专业人员。
相关阅读
html叫什么, HTML的来源与开展

html叫什么, HTML的来源与开展

HTML是超文本符号言语(HyperTextMarkupLanguage)的缩写,它是一种用于创立网页的规范符号言语。HTML能...

2024-12-23

html水平居中代码

html水平居中代码

1.文本内容:关于文本内容,可以运用`textalign:center;`款式来使其水平居中。2.块级元素:关于块级元素(如``、...

2024-12-23

vue翻滚字幕,Vue完成翻滚字幕的具体教程

vue翻滚字幕,Vue完成翻滚字幕的具体教程

在Vue中完成翻滚字幕作用,能够经过运用CSS动画或许JavaScript来完成。下面我会供给两种办法来完成这个功用。办法一:运用CS...

2024-12-23

css表格边框,款式、技巧与运用

css表格边框,款式、技巧与运用

1.设置表格边框宽度、款式和色彩:```csstable{border:2pxsolidblack;}```2.设置表格...

2024-12-23

html5页面布局,HTML5页面布局的根本结构

html5页面布局,HTML5页面布局的根本结构

2.呼应式布局:呼应式布局是指网页能够依据不同的设备和屏幕尺度主动调整布局,以供给最佳的用户体会。这一般经过运用CSS媒体查询来完...

2024-12-23

热门标签