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父组件给子孙组件传值(provide && inject) -> 正文阅读

[JavaScript知识库]vue父组件给子孙组件传值(provide && inject)

vue框架传值常用的有:

1、父传子,在父组件里面的子组件上通过v-bind绑定一个变量传给子组件,对应的子组件里面通过props来接受;

2、子传父:在父组件里面的子组件上自定义个一个方法,用来接受子组件传上来的数据,代码示例如下:

父组件代码片段:

//父组件

<condition-com
   :vessel="vessel"
   @changeLeftComponnet="changeLeftComponnet"
/>

// 父组件里面定义的子组件conditionCom,在conditionCom组件上面自定义一个方changeLeftComponnet,用来接受子组件传给父组件的数据,接受的方式如下:

changeLeftComponnet(val) {
    // 这里可以做任何的事情
    this.leftComponentName = val     
},

子组件代码片段:

<div @click='handlerChange'>
    111222333
</div>


handlerChange(){
    // 这个changeLeftComponnet就是父组件自定义的方法名,必须保持一致,后面的为传给父组件的数据
    this.$emit('changeLeftComponnet', 112233)
}

3、provide、inject:父组件给子孙组件传值

使用方法参考demo:

父组件:

<template>
  <div>
    <h2>CHINESE PORT</h2>
    <h2>这是父组件: {{ father }}</h2>
    <son-com />
  </div>
</template>

<script>
import sonCom from './sonCom.vue'
export default {
  components: { sonCom },
  provide() {
    return {
      sonDate: '子组件数据',
      childDate: '孙组件数据'
    }
  },
  data() {
    return {
      father: '父组件数据'
    }
  },
  methods: {

  }
}
</script>

<style lang='scss' scoped>

</style>

子组件sonCom:

<template>
  <div>
    <h3>这是子组件: {{ sonDate }}</h3>
    <grand-child-com />
  </div>
</template>

<script>
import grandChildCom from './grandChildCom.vue'
export default {
  components: { grandChildCom },
  inject: ['sonDate']
}
</script>

<style>

</style>

孙组件grandChildCom:

<template>
  <div>
    <h4>这是孙组件: {{ childDate }} </h4>
  </div>
</template>

<script>
export default {
  inject: ['childDate']
}
</script>

<style>

</style>

运行之后的页面效果为:

?4.父子、兄弟、跨级:eventBus.js
这种方法通过一个空的 Vue 实例作为中央事件总线(事件中心),用它来( e m i t ) 触 发 事 件 和 ( emit)触发事件和( emit)触发事件和(on)监听事件,巧妙而轻量地实现了任何组件间的通信。

5.通信插件:PubSub.js

6.vuex
vuex 是 vue 的状态管理器,存储的数据是响应式的。只需要把共享的值放到vuex中,其他需要的组件直接获取使用即可;

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-18 11:06:33  更:2021-11-18 11:08:26 
 
开发: 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/4 10:14:42-

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