全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解vue跨组件通信的几种方法

在开发组件的时候,一定会遇到组件的通信,比如点击一个图标出现弹窗和蒙层,这三个分别是不同的组件。管理他们之间的状态就成了问题。

props双向绑定

通过 sync 双向绑定,属性变化会同步到所有组件,这也是最简单的实现方式,缺点是属性会比较多。实现方式如下

App.vue 文件

<template>
 <div id="app">
  <mask :hide-mask.sync="hideMask"></mask>
  <dialog :hide-dialog.sync="hideDialog" :hide-mask.sync="hideMask"></dialog>
  <dialog-icon :hide-dialog.sync="hideDialog" :hide-mask.sync="hideMask"></dialog-icon>
 </div>
</template>

<script>
import mask from './components/mask/index'
import dialog from './components/dialog/index'
import dialogIcon from './components/dialog-icon/index'

export default {
 components: {
  mask,
  dialog,
  dialogIcon
 },
 data () {
  return {
   hideMask: true,
   hideDialog: true
  }
 }
}
</script>

component/dialog/index.vue 文件

<template>
 <section class="dialog" :class="{ 'hide': hideDialog }">
  <div class="dialog-close" @click="hide()"></div>
 </section>
</template>

<script>
export default {
 props: ['hideDialog', 'hideMask'],
 methods: {
  hide () {
   this.hideDialog = !this.hideDialog
   this.hideMask = !this.hideMask
  }
 }
}
</script>

component/dialog-icon/index.vue 文件

<template>
 <section class="dialog-icon" @click="show()">点击出现弹窗</section>
</template>

<script>
export default {
 props: ['hideDialog', 'hideMask'],
 methods: {
  show () {
   this.hideDialog = !this.hideDialog
   this.hideMask = !this.hideMask
  }
 }
}
</script>

component/mask/index.vue 文件

<template>
 <div class="mask" :class="{ 'hide': hideMask }"></div>
</template>

<script>
export default {
 props: ['hideMask']
}
</script>

自定义事件

子组件 $dispatch() 派发事件传递给父组件,父组件 $broadcast() 广播事件传递给子组件,这种方式虽然减少了props的使用,但是需要额外定义几个事件,状态多了就会变得很复杂,实现方法如下

App.vue 文件

<template>
 <div id="app">
  <mask></mask>
  <dialog></dialog>
  <dialog-icon></dialog-icon>
</template>

<script>
import mask from './components/mask/index'
import dialog from './components/dialog/index'
import dialogIcon from './components/dialog-icon/index'

export default {
 components: {
  mask,
  dialog,
  dialogIcon
 },
 data () {
  return {
   hideMask: true,
   hideDialog: true
  }
 },
 events: {
  'dialog-dispatch' () {
   this.hidedialog = !this.hidedialog
   this.$broadcast('dialog-broadcast')
  },
  'mask-dispatch' () {
   this.hideMask = !this.hideMask
   this.$broadcast('mask-broadcast')
  }
 }
}
</script>

component/dialog-icon/index.vue 文件

<template>
 <section class="dialog-icon" @click="show()">点击出现弹窗</section>
</template>

<script>
export default {
 methods: {
  show () {
   this.$dispatch('dialog-dispatch')
   this.$dispatch('mask-dispatch')
  }
 },
 events: {
  'dialog-broadcast' () {
   this.hideDialog = !this.hideDialog
  }
 },
 data () {
  return {
   hideDialog: this.$parent.hideDialog,
   hideMask: this.$parent.hideMask
  }
 }
}
</script>

component/dialog/index.vue 文件

<template>
 <section class="dialog" :class="{ 'hide': hideDialog }">
  <div class="dialog-close" @click="hide()"></div>
 </section>
</template>

<script>
export default {
 methods: {
  hide () {
   this.$dispatch('dialog-dispatch')
   this.$dispatch('mask-dispatch')
  }
 },
 events: {
  'dialog-broadcast' () {
   this.hideDialog = !this.hideDialog
  }
 },
 data () {
  return {
   hideDialog: this.$parent.hideDialog,
   hideMask: this.$parent.hideMask
  }
 }
}
</script>

component/mask/index.vue 文件

<template>
 <div class="mask" :class="{ 'hide': hideMask }"></div>
</template>

<script>
export default {
 data () {
  return {
   hideMask: this.$parent.hideMask
  }
 },
 events: {
  'mask-broadcast' () {
   this.hideMask = !this.hideMask
  }
 }
}
</script>

Vuex

状态统一放store管理,修改状态通过mutations,组件通过action调用mutations,虽然有点绕,但是所有东西放一起后期会更好维护,实现方法如下

App.vue 文件

<template>
 <div id="app">
  <mask></mask>
  <dialog></dialog>
  <dialog-icon></dialog-icon>
 </div>
</template>

<script>
import mask from './components/mask/index'
import dialog from './components/dialog/index'
import dialogIcon from './components/dialog-icon/index'

export default {
 components: {
  mask,
  dialog,
  dialogIcon
 }
}
</script>

component/dialog/index.vue 文件

<template>
 <section class="storehouse dialog" :class="{ 'hide': isHideDialog }">
  <div class="dialog-close" @click="hideDialog()"></div>
 </section>
</template>

<script>
import { hideDialog } from '../../vuex/actions'

export default {
 vuex: {
  state: {
   isHideDialog: state => state.isHideDialog
  },
  actions: {
   hideDialog
  }
 }
}
</script>

component/dialog-icon/index.vue 文件

<template>
 <section class="storehouse-icon" @click="hideDialog()">点击出现弹窗</section>
</template>

<script>
import { hideDialog } from '../../vuex/actions'

export default {
 vuex: {
  actions: {
   hideDialog
  }
 }
}
</script>

component/mask/index.vue 文件

<template>
 <div class="mask" :class="{ 'hide': isHideMask }"></div>
</template>

<script>
export default {
 vuex: {
  state: {
   isHideMask: state => state.isHideMask
  }
 }
}
</script>

vuex/store.js 文件

import Vue from 'vue'
import Vuex from 'vuex'
import mutations from './mutations'

Vue.use(Vuex)

const state = {
 isHideMask: true,
 isHideDialog: true
}

const store = new Vuex.Store({
 state,
 mutations
})

if (module.hot) {
 module.hot.accept(['./mutations'], () => {
  const mutations = require('./mutations').default
  store.hotUpdate({
   mutations
  })
 })
}

export default store

vuex/mutations.js 文件

import {
 HIDEDIALOG
}
from './mutation-types'

export
default {
 [HIDEDIALOG] (state) {
  state.isHideDialog = !state.isHideDialog
  state.isHideMask = !state.isHideMask
 }
}

vuex/mutations-types.js 文件

export const HIDEDIALOG = 'HIDEDIALOG'

vuex/action.js 文件

import { HIDEDIALOG } from './mutation-types'
export const hideDialog = ({ dispatch }) => dispatch(HIDEDIALOG)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# vue  # 跨组件通信  # vuex  # 跨组件调用方法  # Vue.js每天必学之组件与组件间的通信  # Vuejs第十篇之vuejs父子组件通信  # vue中组件通信的八种方式(值得收藏!)  # vue 组件间的通信之子组件向父组件传值的方式  # Vue 之孙组件向爷组件通信的实现  # 深入探讨Vue.js组件和组件通信  # 详解vue组件通信的三种方式  # Vue3的7种种组件通信详情  # 详细聊聊vue组件是如何实现组件通讯的  # 绑定  # 方法如下  # 几个  # 就会  # 较多  # 自定义  # 会比  # 最简单  # 这三个  # 他们之间  # 大家多多  # 很复杂  # 后期  # 这也是  # 减少了  # 就成了  # div  # id  # app  # lt 


相关文章: ,想在网上投简历,哪几个网站比较好?  兔展官网 在线制作,怎样制作微信请帖?  制作营销网站公司,淘特是干什么用的?  教育培训网站制作流程,请问edu教育网站的域名怎么申请?  定制建站流程步骤详解:一站式方案设计与开发指南  如何零成本快速生成个人自助网站?  c++怎么用jemalloc c++替换默认内存分配器【性能】  佛山网站制作系统,佛山企业变更地址网上办理步骤?  洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  广平建站公司哪家专业可靠?如何选择?  C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  电商平台网站制作流程,电商网站如何制作?  金*站制作公司有哪些,金华教育集团官网?  北京网站制作网页,网站升级改版需要多久?  青岛网站建设如何选择本地服务器?  制作旅游网站html,怎样注册旅游网站?  php json中文编码为null的解决办法  如何快速搭建高效WAP手机网站?  魔方云NAT建站如何实现端口转发?  如何在建站之星网店版论坛获取技术支持?  如何用虚拟主机快速搭建网站?详细步骤解析  如何挑选高效建站主机与优质域名?  宝塔建站助手安装配置与建站模板使用全流程解析  油猴 教程,油猴搜脚本为什么会网页无法显示?  建站org新手必看:2024最新搭建流程与模板选择技巧  智能起名网站制作软件有哪些,制作logo的软件?  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  如何在万网自助建站平台快速创建网站?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  网站设计制作企业有哪些,抖音官网主页怎么设置?  建站之星CMS五站合一模板配置与SEO优化指南  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  高防服务器租用指南:配置选择与快速部署攻略  行程制作网站有哪些,第三方机票电子行程单怎么开?  如何快速上传自定义模板至建站之星?  c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】  盘锦网站制作公司,盘锦大洼有多少5G网站?  网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?  北京专业网站制作设计师招聘,北京白云观官方网站?  红河网站制作公司,红河事业单位身份证如何上传?  公司网站制作价格怎么算,公司办个官网需要多少钱?  如何在阿里云ECS服务器部署织梦CMS网站?  如何在宝塔面板创建新站点?  建站之星伪静态规则如何正确配置?  制作网站的基本流程,设计网站的软件是什么? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。