Vue 组件传值的十种方法 敲黑板~~~~~敲黑板~~~~ 是十种

2023-11-21 22:59

本文主要是介绍Vue 组件传值的十种方法 敲黑板~~~~~敲黑板~~~~ 是十种,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 父向子传值

  • 父组件里子组件标签上绑定自定义属性,子组件通过props接受
    代码实例

在这里插入图片描述

2.子向父传值

  • 父组件:在子组件标签上定义一个事件
  • 子组件:在子组件通过$emit调用父组件定义的事件,并携带参数。

代码示例:在这里插入图片描述

3.eventBus 事件总线

  • 可以通过EventBus进行信息的发布于订阅。(创建一个能够访问到事件总线)

3.1 在vueprototype原型上挂载是事件总线(main.js文件中)。

Vue.prototype.$eventBus = new Vue()

3.2 发送数据

this.$eventBus.$emit('事件名', 传递参数)

3.3 接受数据

    this.$eventBus.$on('事件名', (接受参数) => {//进行操作})

代码实例:

要求:将Father.vue里面的数据传到Grandson.vue里面

在这里插入图片描述

4. ref

通过添加ref和$refs配合,也可以很方便的获取子组件,访问调用子组件的属性即方法。

用refs指定子组件: <子组件 ref=“ref名”/>
通过$refs访问子组件: this.$refs

代码实例:

<template><div>父组件<Son1 ref="son1"/><Son2 ref="son2"/></div>
</template>
<script>
import Son1 from './Son1.vue'
import Son2 from './Son2.vue'export default {components: {Son1,Son2},mounted () {console.log(this.$refs.son1)}
}
</script>

$refs可以获取到整个子组件。并且可以对齐进行操作
在这里插入图片描述

5. $children 获取子组件集合

  • 父组件中,$children返回的是一个组件集合,如果你清楚子组件的顺序,你也可以使用下标操作。

语法:

this.$children

代码实例:

<template><div>父组件<Son1/><Son2/></div>
</template>
<script>
import Son1 from './Son1.vue'
import Son2 from './Son2.vue'export default {components: {Son1,Son2},mounted () {console.log(this.$children) }
}
</script>

获取结果:

  • 将子组件获取放入一个数据中,可以通过索引获取(this.$children[]
    在这里插入图片描述

6.$parent获取父组件。

  • 子组件中$parent直接指向父组件。

语法:

this.$parent

代码实例:
子组件中

<template><div>子组件</div>
</template>
<script>
export default {mounted () {console.log(this.$parent)}
}
</script>

获取结果:
在这里插入图片描述

总结:ref,$children,$parent

  • 三种办法获取的是类似的
  • 一般是用ref和$parent获取是相对比较准确的比较多获取比较准确
  • 注意使用$children要注意,通过下标获取,一旦组件下标发生改变就会出问题

7.provide与inject 子孙组件传值

  • provide和injiect是成对出现的
  • 作用:用于父组件像子孙组件出传递数据

使用方法:

  • provide在父组件中,返回要传给下级的数据
  • inject在需要使用这个数据的子孙组价中注入数据。(不论组件层级有多深)
  • inject使用方法与props一样,但是他们两个不冲突,也就是说两个可以同时使用。

在这里插入图片描述

8.$attrs 父给孙进行传值

  • $attrs 就像是一个语法糖,原理还是父传给子,子再传给孙
  • $attrs 优化了在子组件中的传递的步骤
  • $attrs 一般搭配 $listeners使用
    在这里插入图片描述
    代码实例:
    在这里插入图片描述

9. $listeners 孙级组件像父级以上传值

  • $listeners 做法极其相似,$listeners是通过触发事件,传的是函数
    在这里插入图片描述
    代码实例:
    在这里插入图片描述

10.Vuex

Vuex是专为Vue.js应用程序开发的状态管理模块,它采用了集中式储存管理应用的所有组件的状态。

Vuex有两个特点:

  1. Vuex的数据是响应式的,当一个组件改变了Vue的中的转态,其他用到此状态的组件都会跟新
  2. 不能直接改变store里面的状态,必须通过store中的commit来提交修改,mutation里面修改

Vuex的五个核心分别是:

  1. states:储存状态。
  2. mutations:修改数据。
  3. getters:计算属性,对数据进行进一步技术并返回
  4. actions:可以包含任意异步操作,actions里面一定会有commit属性调用mutations里 面的方法
  5. models:模块拆分

Vuex这里我就不做详细解释了,之前写过一篇Vuex的帖子>>>>>>>>>>>Vuex

这篇关于Vue 组件传值的十种方法 敲黑板~~~~~敲黑板~~~~ 是十种的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/405683

相关文章

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

电脑死机无反应怎么强制重启? 一文读懂方法及注意事项

《电脑死机无反应怎么强制重启?一文读懂方法及注意事项》在日常使用电脑的过程中,我们难免会遇到电脑无法正常启动的情况,本文将详细介绍几种常见的电脑强制开机方法,并探讨在强制开机后应注意的事项,以及如何... 在日常生活和工作中,我们经常会遇到电脑突然无反应的情况,这时候强制重启就成了解决问题的“救命稻草”。那

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

Python中的魔术方法__new__详解

《Python中的魔术方法__new__详解》:本文主要介绍Python中的魔术方法__new__的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、核心意义与机制1.1 构造过程原理1.2 与 __init__ 对比二、核心功能解析2.1 核心能力2.2