详解Vue3.x中组件间参数传递的示例代码

 更新时间:2024年03月04日 08:36:33   作者:慕仲卿  
在 Vue3.x 中,组件间的参数传递是构建复杂应用时不可或缺的一部分,无论是父子组件还是兄弟组件之间,合理的数据流动都是保持应用状态一致性和可维护性的关键,本文将通过示例代码,详细介绍 Vue3.x 中组件间如何传递参数,需要的朋友可以参考下

1. 父子组件间参数传递

Props 传递数据

父组件向子组件传递数据通常使用 props

步骤 1: 定义子组件

假设有一个子组件 ChildComponent.vue,希望从父组件接收一个 message 参数。

// ChildComponent.vue
<script setup>
import { defineProps } from 'vue';

const props = defineProps({
  message: String
});
</script>

<template>
  <div>来自父组件的消息:{{ message }}</div>
</template>

这里,我们使用了 Vue3.x 的 Composition API 中的 defineProps 函数来定义接收的 props

步骤 2: 父组件传递数据

在父组件中,通过 ChildComponent 的标签属性来传递数据。

// ParentComponent.vue
<template>
  <ChildComponent message="Hello, Vue3!"></ChildComponent>
</template>

<script setup>
import ChildComponent from './ChildComponent.vue';
</script>

$emit 传递事件

子组件向父组件传递数据,通常是通过事件触发的方式,使用 $emit

子组件定义

在子组件中定义一个按钮,点击时触发一个自定义事件 update,并传递数据给父组件。

// ChildComponent.vue
<script setup>
import { defineEmits } from 'vue';

const emit = defineEmits(['update']);
const updateMessage = () => {
  emit('update', '来自子组件的新消息');
};
</script>

<template>
  <button @click="updateMessage">更新消息</button>
</template>

父组件接收

在父组件中,监听这个 update 事件,并处理数据。

// ParentComponent.vue
<template>
  <ChildComponent @update="handleUpdate"></ChildComponent>
</template>

<script setup>
import { ref } from 'vue';
import ChildComponent from './ChildComponent.vue';

const message = ref('');

const handleUpdate = (newMessage) => {
  message.value = newMessage;
};
</script>

2. 兄弟组件间参数传递

兄弟组件之间的参数传递稍微复杂一些,因为它们没有直接的父子关系。常见的解决方案是通过共享的全局状态管理(如 Vuex)或者通过父组件作为桥梁。

使用父组件作为桥梁

假设有两个兄弟组件 BrotherComponent1BrotherComponent2,它们通过父组件 ParentComponent 传递数据。

步骤 1: 兄弟组件定义

兄弟组件1定义一个方法,通过 $emit 向父组件发送数据。

// BrotherComponent1.vue
<script setup>
import { defineEmits } from 'vue';

const emit = defineEmits(['send']);
const sendMessage = () => {
  emit('send', '来自兄弟1的消息');
};
</script>

<template>
  <button @click="sendMessage">发送消息给兄弟2</button>
</template>

兄弟组件2通过 props 接收数据。

// BrotherComponent2.vue
<script setup>
import { defineProps } from 'vue';

const props = defineProps({
  message: String
});
</script>

<template>
  <div>{{ message }}</div>
</template>

步骤 2: 父组件作为中介

父组件监听 BrotherComponent1 的事件,并将数据通过 props 传递给 BrotherComponent2

// ParentComponent.vue
<template>
  <BrotherComponent1 @send="handleSend"></BrotherComponent1>
  <BrotherComponent2 :message="message"></BrotherComponent2>
</template>

<script setup>
import { ref } from 'vue';
import BrotherComponent1 from './BrotherComponent1.vue';
import BrotherComponent2 from './BrotherComponent2.vue';

const message = ref('');

const handleSend = (msg) => {
  message.value = msg;
};
</script>

对于兄弟组件间的数据传递,除了通过父组件作为中介之外,使用 Vuex 进行全局状态管理是另一种常见且强大的方法。下面介绍如何使用 Vuex 在 Vue3.x 中实现兄弟组件间的参数传递。

使用 Vuex 实现兄弟组件间的参数传递

Vuex 是 Vue 的官方状态管理库,它提供了一个集中存储所有组件的状态的机制,并以相应的规则保证状态以一种可预测的方式发生变化。这使得在不直接关联的组件之间共享状态变得非常方便。

步骤 1: 安装并配置 Vuex

首先,需要在 Vue3.x 项目中安装 Vuex。

npm install vuex@next --save

接下来,在项目中创建一个 Vuex store。假设项目结构中有一个 store 目录,在这个目录下创建 index.js

// store/index.js
import { createStore } from 'vuex';

export default createStore({
  state() {
    return {
      message: ''
    };
  },
  mutations: {
    updateMessage(state, newMessage) {
      state.message = newMessage;
    }
  }
});

在这个 Vuex store 中定义了一个简单的状态 message 和一个用于更新这个状态的 mutation updateMessage

步骤 2: 在 Vue 应用中使用 Vuex store

在 Vue 应用中引入并使用这个 Vuex store。通常在 main.js 中完成这个步骤:

// main.js
import { createApp } from 'vue';
import App from './App.vue';
import store from './store';

createApp(App).use(store).mount('#app');

步骤 3: 在组件中使用 Vuex 状态

至此,任何组件都可以通过 useStore hook 来访问和修改 Vuex store 中的状态。

兄弟组件1 - 发送消息

// BrotherComponent1.vue
<script setup>
import { useStore } from 'vuex';

const store = useStore();

const sendMessage = () => {
  store.commit('updateMessage', '来自兄弟1的消息');
};
</script>

<template>
  <button @click="sendMessage">发送消息给兄弟2</button>
</template>

兄弟组件2 - 接收消息

// BrotherComponent2.vue
<script setup>
import { computed } from 'vue';
import { useStore } from 'vuex';

const store = useStore();
const message = computed(() => store.state.message);
</script>

<template>
  <div>消息:{{ message }}</div>
</template>

在这个示例中,BrotherComponent1 通过调用 Vuex 的 commit 方法来更新状态,而 BrotherComponent2 通过 computed 属性来响应状态的变化,并显示更新后的消息。

3. 组件间的参数透传

参数透传是指在组件嵌套场景中,将外层组件接收到的 props 直接传递给内层组件,而不需要在每一层组件中显式声明所有的 props。这种技术在处理高阶组件或封装库组件时特别有用,可以大幅度减少代码的重复性和复杂性。

使用 v-bind="$attrs" 实现参数透传

在 Vue3.x 中,可以通过 $attrs 属性结合 v-bind 指令来实现参数透传。$attrs 包含了父组件传递给子组件的 props(未被子组件声明为 props 的属性)和监听器(v-on 事件监听器),这使得我们可以轻松地将所有外部属性传递给内层组件。

示例:封装一个透传参数的按钮组件

假设我们有一个 BaseButton.vue 组件,这个组件需要接收多种外部 props 用于控制按钮的样式和行为,但我们不希望在这个组件内部声明所有可能的 props

步骤 1: 定义 BaseButton.vue

// BaseButton.vue
<script setup>
// 注意,这里我们不声明具体的 props
</script>

<template>
  <button v-bind="$attrs">{{ $attrs.label }}</button>
</template>

在 BaseButton 组件中,我们使用了 v-bind="$attrs" 来绑定所有父组件传递的属性。这样,任何在父组件中设置的属性都会自动应用到 button 元素上,包括事件监听器。

步骤 2: 在父组件中使用 BaseButton

// App.vue
<template>
  <BaseButton
    label="点击我"
    class="btn-primary"
    @click="handleClick"
  ></BaseButton>
</template>

<script setup>
const handleClick = () => {
  console.log('按钮被点击了!');
};
</script>

在父组件 App.vue 中,我们向 BaseButton 组件传递了一个 label 属性、一个 class,以及一个点击事件的监听器。所有这些属性和监听器都将通过 $attrs 透传给内部的 button 元素。

通过使用 $attrsv-bind,Vue3.x 允许开发者在组件间高效地透传参数,极大地提高了组件封装的灵活性和可重用性。这种方法尤其适合开发那些需要接收大量外部 props 的基础组件或库组件,可以避免在组件内部手动声明和传递大量的 props,从而简化代码并减少出错的可能。

总结

下表总结了 Vue3.x 中组件间参数传递的方法和步骤:

类型方法步骤代码示例
父子组件间传递Props 传递数据1. 子组件使用 defineProps 定义接收的 props。
2. 父组件通过子组件标签属性传递数据。
子组件:
const props = defineProps({ message: String });父组件:
<ChildComponent message="Hello, Vue3!" />
$emit 传递事件1. 子组件使用 defineEmits 定义事件。
2. 子组件通过事件发送数据。
3. 父组件监听并处理事件。
子组件:
const emit = defineEmits(['update']);父组件:
<ChildComponent @update="handleUpdate" />
兄弟组件间传递使用父组件作为桥梁1. 兄弟组件之一通过 $emit 向父组件发送数据。
2. 父组件通过 props 将数据传递给另一个兄弟组件。
父组件:
<BrotherComponent1 @send="handleSend" /><BrotherComponent2 :message="message" />
使用 Vuex1. 配置 Vuex store 并定义全局状态。
2. 一个兄弟组件通过 Vuex 修改状态。
3. 另一个兄弟组件通过 Vuex 获取状态。
Vuex:
store.commit('updateMessage', '来自兄弟1的消息');const message = computed(() => store.state.message);
参数透传使用 $attrs1. 外层组件接收到的 props 直接通过 $attrsv-bind 透传给内层组件。
2. 内层组件自动继承所有外部属性和事件监听器,无需显式声明。
<button v-bind="$attrs">{{ $attrs.label }}</button>

结语

在 Vue3.x 中,组件间的参数传递是维持数据流动和组件通信的重要机制。利用 props$emit 可以方便地在父子组件间进行数据交互,而通过父组件作为桥梁或使用全局状态管理则可以实现兄弟组件或更复杂关系组件间的数据传递。掌握这些技巧将有助于构建更加高效和可维护的 Vue 应用。

以上就是详解Vue3.x中组件间参数传递的示例代码的详细内容,更多关于Vue3.x组件间参数传递的资料请关注脚本之家其它相关文章!

相关文章

  • Vue绑定对象与数组变量更改后无法渲染问题解决

    Vue绑定对象与数组变量更改后无法渲染问题解决

    这篇文章主要介绍了Vue绑定对象与数组变量更改后无法渲染问题解决,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • Vue如何使用混合Mixins和插件开发详解

    Vue如何使用混合Mixins和插件开发详解

    这篇文章主要介绍了Vue如何使用混合Mixins和插件开发详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • Vue axios与Go Frame后端框架的Options请求跨域问题详解

    Vue axios与Go Frame后端框架的Options请求跨域问题详解

    这篇文章主要介绍了Vue axios与Go Frame后端框架的Options请求跨域问题详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • 关于eslint+prettier+husky的配置及说明

    关于eslint+prettier+husky的配置及说明

    这篇文章主要介绍了关于eslint+prettier+husky的配置及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • vue二次封装一个高频可复用组件的全过程

    vue二次封装一个高频可复用组件的全过程

    在开发Vue项目我们一般使用第三方UI组件库进行开发,但是这些组件提供的接口并不一定满足我们的需求,这时我们可以通过对组件库组件的二次封装,来满足我们特殊的需求,这篇文章主要给大家介绍了关于vue二次封装一个高频可复用组件的相关资料,需要的朋友可以参考下
    2022-10-10
  • Vue2.0父子组件传递函数的教程详解

    Vue2.0父子组件传递函数的教程详解

    这篇文章主要介绍了Vue2.0父子组件传递函数的教程详解,需要的朋友可以参考下
    2017-10-10
  • Vue2与Vue3中Ref绑定元素方式

    Vue2与Vue3中Ref绑定元素方式

    这篇文章主要介绍了Vue2与Vue3中Ref绑定元素方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • 用vue设计一个数据采集器

    用vue设计一个数据采集器

    这篇文章主要介绍了如何用vue设计一个数据采集器,帮助大家更好的理解和学习使用vue框架,感兴趣的朋友可以了解下
    2021-04-04
  • vue金额格式化保留两位小数的实现

    vue金额格式化保留两位小数的实现

    这篇文章主要介绍了vue金额格式化保留两位小数的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • vue.js+element-ui动态配置菜单的实例

    vue.js+element-ui动态配置菜单的实例

    今天小编就为大家分享一篇vue.js+element-ui动态配置菜单的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09

最新评论