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

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小时内与您取得联系。