IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue 组件传值的十种方法 敲黑板~~~~~敲黑板~~~~ 是十种 -> 正文阅读

[JavaScript知识库]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

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-15 15:45:41  更:2021-11-15 15:48:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/1 10:21:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码