位置: IT常识 - 正文

Vue 组件之间传值(vue组件之间传值几种方法)

编辑:rootadmin
Vue 组件之间传值

推荐整理分享Vue 组件之间传值(vue组件之间传值几种方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue组件之间传递数据,vue组件之间传递方法,vue组件之间传参数,vue组件之间传值详解,vue组件之间传值几种方法,vue 组件之间传值几种方式,vue组件之间传值详解,vue组件之间传值几种方法,内容如对您有帮助,希望把文章链接给更多的朋友!

一、Vue 组件之间传值的主要方法

Vue 3 对于组件之间传递值的基本思想与 Vue 2 相似,但是有一些语法和 API 上的改变,主要的传值方法有以下几种:

1、父组件向子组件传值,使用 props:可以通过在子组件上绑定 props,然后在父组件中通过 v-bind 绑定相应的数据来传递数据。

2、子组件向父组件传值,使用 $emit:可以通过在子组件中使用 $emit 触发自定义事件,并在父组件中使用 v-on 监听相应的事件来传递数据。

3、兄弟组件之间传值:可以通过使用一个共同的父组件,然后将需要共享的数据放在父组件的 data 中,再通过 props 将数据传递给各自的子组件。

4、跨级组件传值,使用 provide 和 inject(同样适用于父子组件传值):provide 可以在祖先组件中定义一个值或者方法,然后在子孙组件中使用 inject 来注入这个值或者方法。

5、使用全局事件总线:可以使用 Vue 的事件机制,通过在 Vue 实例上使用 $on 来监听事件,然后在其他组件中使用 $emit 触发相应的事件来传递数据。这种方式可以在任意组件之间传递数据。

6、使用 Vuex:当应用的数据状态比较复杂或者需要在多个组件之间共享时,可以使用 Vuex,它是一个专为 Vue.js 应用程序开发的状态管理模式。可以在任何组件中访问和修改 Vuex 存储的数据,通过 mutations 来修改状态,通过 actions 来触发 mutations。这种方式可以方便地在不同的组件中进行状态管理和数据共享。

7、使用 $attrs 和 $listeners,$attrs 和 $listeners 是常用的两个特殊属性,它们可以用来向组件传递属性和事件监听器。

8、使用 $refs:可以使用 Vue 提供的 $refs 属性来获取组件实例,然后通过调用组件的方法来进行数据传递。这种方式不推荐使用,因为不易维护和调试。

9、使用事件总线库:可以使用 Vue.js 的第三方库如 Event Bus、Tiny-Emmiter 等来传递数据。这些库提供了一种方便、简单的方式来在不同的组件之间进行事件传递。但是需要注意,使用第三方库可能会增加项目的复杂性和维护成本。

二、Vue 2 组件之间传值示例代码

1、父组件向子组件传值,使用 props:可以通过在子组件上绑定 props,然后在父组件中通过 v-bind 绑定相应的数据来传递数据。

父组件中的代码:

<template> <div> <child-component :prop-a="dataA"></child-component> </div></template><script>import ChildComponent from './ChildComponent.vue';export default { components: { ChildComponent, }, data() { return { dataA: 'data from parent', }; },};</script>

 子组件中的代码:

<template> <div> {{ propA }} </div></template><script>export default { props: { propA: String, },};</script>2、子组件向父组件传值,使用 $emit:可以通过在子组件中使用 $emit 触发自定义事件,并在父组件中使用 v-on 监听相应的事件来传递数据。

子组件中的代码:

<template> <div> <button @click="sendDataToParent">Send Data To Parent</button> </div></template><script>export default { data() { return { dataB: 'data from child', }; }, methods: { sendDataToParent() { this.$emit('send-data', this.dataB); }, },};</script>

 父组件中的代码:

<template> <div> <child-component @send-data="receiveDataFromChild"></child-component> </div></template><script>import ChildComponent from './ChildComponent.vue';export default { components: { ChildComponent, }, methods: { receiveDataFromChild(dataB) { console.log(dataB); }, },};</script>3、兄弟组件之间传值:可以通过使用一个共同的父组件,然后将需要共享的数据放在父组件的 data 中,再通过 props 将数据传递给各自的子组件。

父组件中的代码:

<template> <div> <child-a :prop-a="dataA"></child-a> <child-b :prop-b="dataB"></child-b> </div></template><script>import ChildA from './ChildA.vue';import ChildB from './ChildB.vue';export default { components: { ChildA, ChildB, }, data() { return { dataA: 'data from parent to child a', dataB: 'data from parent to child b', }; },};</script>

 子组件 A 中的代码:

<template> <div> {{ propA }} </div></template><script>export default { props: { propA: String, },};</script>

 子组件 B 中的代码:

<template> <div> {{ propB }} </div></template><script>export default { props: { propB: String, },};</script>4、跨级组件传值,使用 provide 和 inject(该方法也可用于父子组件传值):provide 可以在祖先组件中定义一个值或者方法,然后在子孙组件中使用 inject 来注入这个值或者方法。

祖先组件中的代码:

<template> <div> <child-a></child-a> </div></template><script>import ChildA from './ChildA.vue';export default { components: { ChildA, }, provide() { return { sharedData: 'data from ancestor', }; },};</script>

 子孙组件 A 中的代码:

<template> <div> {{ sharedData }} </div></template><script>export default { inject: ['sharedData'],};</script>5、使用全局事件总线:可以使用 Vue 的事件机制,通过在 Vue 实例上使用 $on 来监听事件,然后在其他组件中使用 $emit 触发相应的事件来传递数据。这种方式可以在任意组件之间传递数据。

在 main.js 中定义一个空的 Vue 实例作为事件总线:

import Vue from 'vue';export const bus = new Vue();

 子组件 A 中的代码:

<template> <div> <button @click="sendDataToSibling">Send Data To Sibling</button> </div></template><script>import { bus } from './main';export default { methods: { sendDataToSibling() { bus.$emit('send-data', 'data from child a'); }, },};</script>Vue 组件之间传值(vue组件之间传值几种方法)

 子组件 B 中的代码:

<template> <div> {{ dataFromSibling }} </div></template><script>import { bus } from './main';export default { data() { return { dataFromSibling: '', }; }, mounted() { bus.$on('send-data', (data) => { this.dataFromSibling = data; }); },};</script>6、使用 Vuex:当应用的数据状态比较复杂或者需要在多个组件之间共享时,可以使用 Vuex,它是一个专为 Vue.js 应用程序开发的状态管理模式。可以在任何组件中访问和修改 Vuex 存储的数据,通过 mutations 来修改状态,通过 actions 来触发 mutations。这种方式可以方便地在不同的组件中进行状态管理和数据共享。

在 store.js 中定义一个 Vuex store:

import Vue from 'vue';import Vuex from 'vuex';Vue.use(Vuex);const store = new Vuex.Store({ state: { dataC: 'data from Vuex', }, mutations: { updateDataC(state, payload) { state.dataC = payload; }, },});export default store;

 子组件 A 中的代码:

<template> <div> <button @click="sendDataToSibling">Send Data To Sibling</button> </div></template><script>import { mapMutations } from 'vuex';export default { methods: { ...mapMutations(['updateDataC']), sendDataToSibling() { this.updateDataC('data from child a'); }, },};</script>

 子组件 B 中的代码:

<template> <div> {{ dataC }} </div></template><script>import { mapState } from 'vuex';export default { computed: { ...mapState(['dataC']), },};</script>7、父子组件传值,使用 $attrs 和 $listeners:

$attrs 是一个包含了父组件传递给子组件的所有属性的对象,可以在子组件中通过访问 $attrs 来获取这些属性。如果不希望某些属性传递到子组件中,可以在子组件中使用 v-bind="$attrs" 并指定排除的属性名称,或者在父组件中使用 .sync 修饰符,将属性绑定到子组件的一个名为 $attrs 的属性上。

$listeners 是一个包含了父组件传递给子组件的所有事件监听器的对象,可以在子组件中通过访问 $listeners 来获取这些事件监听器。如果需要在子组件中监听某个事件,可以使用 v-on="$listeners" 将所有的事件监听器绑定到子组件上。

$attrs 和 $listeners 是常用的两个特殊属性,它们可以用来向组件传递属性和事件监听器。假设我们有一个父组件和一个子组件,子组件需要接收父组件的一些属性和事件监听器,同时还需要把这些属性和事件传递给子组件的某个子元素。

父组件中的代码:

<template> <div> <child-component :title="title" v-on:click="handleClick" /> </div></template><script>import ChildComponent from './ChildComponent.vue';export default { components: { ChildComponent }, data() { return { title: 'Hello World', }; }, methods: { handleClick() { console.log('Button Clicked'); }, },};</script>

 子组件中的代码:

<template> <div> <button @click="$emit('click')">Click me</button> <div v-bind="$attrs"> <slot /> </div> </div></template><script>export default { inheritAttrs: false, props: { title: { type: String, default: '', }, }, mounted() { console.log(this.$attrs); console.log(this.$listeners); },};</script>

在子组件中,我们使用 v-bind="$attrs" 把所有父组件传递过来的属性绑定到子元素上。同时,我们使用 $emit('click') 来触发父组件传递过来的点击事件。

在子组件 中,需要设置 inheritAttrs: false,来禁止自动将父组件传递的属性绑定到子组件的根元素上。这样,我们就可以使用 v-bind="$attrs" 把所有属性绑定到子元素上。

在 mounted 钩子中,我们可以通过 this.$attrs 和 this.$listeners 来分别访问所有属性和事件监听器。这样,我们就可以在子组件中使用这些属性和事件了。

8、使用 $refs:可以使用 Vue 提供的 $refs 属性来获取组件实例,然后通过调用组件的方法来进行数据传递。这种方式不推荐使用,因为不易维护和调试。

9、使用事件总线库:可以使用 Vue.js 的第三方库如 Event Bus、Tiny-Emmiter 等来传递数据。这些库提供了一种方便、简单的方式来在不同的组件之间进行事件传递。但是需要注意,使用第三方库可能会增加项目的复杂性和维护成本。

三、Vue 3 组件之间传值示例代码

1、Props

Props 是一种在组件之间传递数据的方式,通过在组件标签上使用属性绑定,父组件可以向子组件传递数据。在子组件中,通过在 props 中定义对应的属性名,可以获取到父组件传递过来的数据。

例如,父组件中的模板:

<template> <child-component :message="hello"></child-component></template><script>import ChildComponent from './ChildComponent.vue';export default { components: { ChildComponent }, data() { return { hello: 'Hello from parent!' }; }};</script>

 子组件中的模板:

<template> <div>{{ message }}</div></template><script>export default { props: { message: String }};</script>2、$emit 

$emit  是一种在子组件中触发事件的方式,通过在子组件中使用 $emit 方法,可以向父组件发送数据。在父组件中,通过在子组件标签上使用 v-on 或 @ 语法,可以监听子组件触发的事件,并获取子组件发送的数据。

例如,子组件中的模板:

<template> <button @click="sendMessage">Send Message</button></template><script>export default { methods: { sendMessage() { this.$emit('message-sent', 'Hello from child!'); } }};</script>

 父组件中的模板:

<template> <child-component @message-sent="receiveMessage"></child-component></template><script>import ChildComponent from './ChildComponent.vue';export default { components: { ChildComponent }, methods: { receiveMessage(message) { console.log(message); } }};</script>3、Provide/Inject

Provide/Inject 是一种在祖先组件和后代组件之间共享数据的方式。通过在祖先组件中使用 provide 方法提供数据,在后代组件中使用 inject 方法获取数据。

例如,祖先组件中的模板:

<template> <child-component></child-component></template><script>import ChildComponent from './ChildComponent.vue';export default { components: { ChildComponent }, provide() { return { message: 'Hello from ancestor!' }; }};</script>

 后代组件中的模板:

<template> <div>{{ message }}</div></template><script>export default { inject: ['message']};</script>4、$attrs 和 $listeners

$attrs 和 $listeners 是在 Vue 2 中引入的特性,但在 Vue 3 中也得到了支持。

例如,父组件中的模板:

<template> <child-component message="Hello from parent!" @click="handleClick"></child-component></template><script>import ChildComponent from './ChildComponent.vue';export default { components: { ChildComponent }, methods: { handleClick() { console.log('Clicked!'); } }};</script>

 子组件中的模板:

<template> <div v-bind="$attrs" v-on="$listeners">{{ message }}</div></template><script>export default { props: { message: String }};</script>5、provide/inject 与 props 的结合使用

在 Vue 3 中,provide 和 inject 可以与 props 结合使用,从而实现一种高级的数据传递方式。具体做法是,在祖先组件中使用 provide 方法提供数据,并在后代组件中使用 inject 方法获取数据;同时,在后代组件中,可以在 props 中

本文链接地址:https://www.jiuchutong.com/zhishi/300598.html 转载请保留说明!

上一篇:【chatgpt】chatgpt APi使用 GPT3(chattra)

下一篇:你的应用太慢了,给我司带来了巨额损失,该怎么办(应用加载慢)

  • 博客营销新创意内容的九个寻找素材的方法(博客营销新创意怎么写)

    博客营销新创意内容的九个寻找素材的方法(博客营销新创意怎么写)

  • 哔哩哔哩可以两个人一起看电影吗(哔哩哔哩可以两个手机登录同一个账号吗)

    哔哩哔哩可以两个人一起看电影吗(哔哩哔哩可以两个手机登录同一个账号吗)

  • iphone13日历骚扰信息怎么删除(iphone日历骚扰信息)

    iphone13日历骚扰信息怎么删除(iphone日历骚扰信息)

  • 红米10xpro有呼吸灯的吗(红米10pro有没有呼吸灯)

    红米10xpro有呼吸灯的吗(红米10pro有没有呼吸灯)

  • 苹果手机蓝牙标志没了(苹果手机蓝牙标志一直显示)

    苹果手机蓝牙标志没了(苹果手机蓝牙标志一直显示)

  • 远程上班是什么意思(远程工作有什么优点)

    远程上班是什么意思(远程工作有什么优点)

  • 抖音从哪看好友在线(抖音哪里看好友)

    抖音从哪看好友在线(抖音哪里看好友)

  • 微信群付款怎么设置(微信分付怎么申请)

    微信群付款怎么设置(微信分付怎么申请)

  • 苹果电脑耳机孔在哪(苹果电脑耳机孔图片)

    苹果电脑耳机孔在哪(苹果电脑耳机孔图片)

  • 微信群文件多久过期(微信群文件多久可以撤回,撤回后群文件里还有记录吗)

    微信群文件多久过期(微信群文件多久可以撤回,撤回后群文件里还有记录吗)

  • 户户通高频头坏了的症状(户户通高频头坏了怎么修)

    户户通高频头坏了的症状(户户通高频头坏了怎么修)

  • 华为mate30怎么设置小圆点(华为mate30怎么设置5g网络)

    华为mate30怎么设置小圆点(华为mate30怎么设置5g网络)

  • wiko是哪个国家的(wis是哪个国家的)

    wiko是哪个国家的(wis是哪个国家的)

  • 微信语音笔记怎么做(微信语音笔记怎么制作图例)

    微信语音笔记怎么做(微信语音笔记怎么制作图例)

  • qq电话左边的麦克风什么用(qq电话旁边的麦克风是什么意思)

    qq电话左边的麦克风什么用(qq电话旁边的麦克风是什么意思)

  • 拼多多差评如何取消(拼多差评怎么评)

    拼多多差评如何取消(拼多差评怎么评)

  • 小米手表尊享版和标准版有什么区别(小米手表尊享版值得买吗)

    小米手表尊享版和标准版有什么区别(小米手表尊享版值得买吗)

  • 字体库在哪个文件夹(字体库在哪个位置)

    字体库在哪个文件夹(字体库在哪个位置)

  • 怎么把录音文件分享给微信好友(怎么把录音文件发到qq好友动态)

    怎么把录音文件分享给微信好友(怎么把录音文件发到qq好友动态)

  • 手机微信是怎么开机启动(手机微信是怎么传达信息的)

    手机微信是怎么开机启动(手机微信是怎么传达信息的)

  • 抖音等十人点赞怎么看(抖音等几个人点赞)

    抖音等十人点赞怎么看(抖音等几个人点赞)

  • 小红书地址在哪里修改(小红书地址在哪改)

    小红书地址在哪里修改(小红书地址在哪改)

  • 电脑缩小窗口快捷键(电脑缩小窗口快捷键是啥)

    电脑缩小窗口快捷键(电脑缩小窗口快捷键是啥)

  • 鸿蒙OS系统应用横条怎么关闭?(鸿蒙os程序)

    鸿蒙OS系统应用横条怎么关闭?(鸿蒙os程序)

  • 论文笔记:TIMESNET: TEMPORAL 2D-VARIATION MODELINGFOR GENERAL TIME SERIES ANALYSIS(论文笔记整理软件)

    论文笔记:TIMESNET: TEMPORAL 2D-VARIATION MODELINGFOR GENERAL TIME SERIES ANALYSIS(论文笔记整理软件)

  • 出口货物退税是指
  • 建筑劳务公司做账分录
  • 滴滴的普票可以抵税吗
  • 报税中反写是什么意思
  • 金税系统怎么录入专票
  • 贸易公司没有仓库需要做入库
  • 个体户银行开户是开公户还是私户
  • 开具发票时如何选择对应的商品分类编码?
  • 收益法评估的基本思路
  • 企业有美金收入吗
  • 非本单位费用列支 违反
  • 企业税收滞纳金计入什么科目
  • 现金折扣怎么计算消费税
  • 合同是怎么影响企业纳税的?
  • 洗衣店每个月水电费多少钱
  • 利润表资产处置损益怎么填
  • 专票上少打了开户行账号可以认证吗
  • 计提缴纳社保的会计分录
  • 分期消费的实际收益
  • 技术服务费成本票是什么
  • 个人独资企业取得的股息红利
  • 印花税的征税范围及税率
  • bios如何解除电脑密码
  • win10同步账户
  • 新版edge浏览器极速模式
  • 收到母公司的投资款
  • 如何处理企业所得税纠纷
  • 新会计准则的科目
  • wordpress访客记录怎么看
  • 其他业务收入和其他业务成本区别
  • repair.exe是什么软件
  • 企业安置残疾人如何残联备案
  • php strlen 中文
  • 软件和集成电路杂志官网
  • php solr
  • PHP使用http_build_query()构造URL字符串的方法
  • 财务报表中固定资产清理为什么加借方余额
  • 债务重组利得计入其他收益还是营业外收入
  • 全局平均池化(GAP)层
  • 网络安全网络文明
  • 开多少票就要进多少钱吗
  • 六款小巧的HTTP Server[C语言] 贵贵的博客 开发|架构|开源|共享
  • 分公司能给总公司担保吗
  • 车票增值税抵扣怎么操作
  • 国税联网状态怎么没显示
  • 固定资产折旧范围口诀
  • MySQL导入导出命令
  • 在建工程账务怎么会转到预收账款
  • 保理公司的钱来自哪里
  • 工程设备公司经营范围
  • 其他应付款贷方什么意思
  • 房租费用计入什么现金流量
  • 代扣代缴预提所得税10%是什么意思
  • 货运代理服务开票
  • 招待费汇算清缴一定要调整的吗
  • 商业企业会计制度变迁论文
  • centos6.2安装
  • 打印机向windows发送消息
  • winpsd.exe - winpsd是什么进程
  • linux ll不能用
  • linux如何查看用户的信息
  • jquery加载函数
  • jqueryvalidate验证
  • shell替换文件中指定行的指定内容
  • cmd中文名称
  • 转义字符对应英文
  • bat调用vbs脚本
  • python解析数据
  • android 系统app权限
  • jquery类型转换
  • 安卓手机管家下载
  • android Intent Flags详解
  • python怎么用命令行
  • socks5代理怎么用
  • 电子税务局驱动安装步骤
  • 税务稽查案件办案程序规定
  • 电子发票提取网站
  • 车船税可以异地补办吗
  • 美国有汽车吗
  • 税金乘以12%是什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设