Vue2中跨组件共享公共属性的方法、优缺点与实现

news/2024/7/8 10:27:34 标签: vue.js, 前端, javascript

一、vuex(最常用)

优缺点

  • 优点:集中管理状态,组件间解耦,易于调试和测试。
  • 缺点:学习成本较高,对于小项目可能过于复杂。

适用场景

  • 大型、复杂的单页面应用(SPA)。
  • 需要全局管理状态的应用。
javascript">// store.js  
import Vue from 'vue'  
import Vuex from 'vuex'  
  
Vue.use(Vuex)  
  
export default new Vuex.Store({  
  state: {  
    message: 'Hello from Vuex!'  
  },  
  mutations: {  
    setMessage(state, msg) {  
      state.message = msg  
    }  
  }  
})  
  

// 在组件中使用  
<template>  
  <div>{{ message }}</div>  
</template>  
  
<script>  
import { mapState } from 'vuex'  
  
export default {  
  computed: {  
    ...mapState(['message'])  
  }  
}  
</script>

 二、事件总线(Event Bus)

优缺点

  • 优点:简单易用,适用于简单的组件间通信。
  • 缺点:当项目较大时,事件管理可能会变得混乱。

适用场景

  • 中小型项目。
  • 简单的组件间通信。
javascript">// event-bus.js  
import Vue from 'vue' 
// 创建一个新的Vue实例作为事件总线 
export const EventBus = new Vue()  
  
// 在组件中触发事件  
EventBus.$emit('customEvent', { message: 'Hello from EventBus!' })  
  

// 在另一个组件中监听事件  
EventBus.$on('customEvent', (payload) => {  
  console.log(payload.message)  
})  
  
// 组件销毁时移除监听  
beforeDestroy() {  
  EventBus.$off('customEvent')  
}

三、provide / inject

优缺点

  • 优点:适用于跨层级传递数据,无需每层都显式传递。
  • 缺点:可能导致组件间耦合度过高,数据流动难以追踪。

适用场景

  • 组件树中的深层嵌套关系。
  • 跨层级传递少量数据的场景。

在祖先组件中使用provide选项来提供数据,然后在后代组件中使用inject选项来注入数据。

javascript">// 祖先组件  
export default {  
  provide() {  
    return {  
      message: 'Hello from provide/inject!'  
    }  
  }  
}  
  
// 后代组件  
export default {  
  inject: ['message'],  
  mounted() {  
    console.log(this.message)  
  }  
}

四、mixins

优缺点

  • 优点:代码复用度高,可以在多个组件之间共享。
  • 缺点:可能导致命名冲突,且mixin中的生命周期钩子会在组件的生命周期钩子之前调用,可能导致意外的副作用。

适用场景

  • 当多个组件需要共享相似的逻辑或数据时。
  • 需要在多个组件中复用某些方法和数据时

创建一个包含共享属性和方法的mixin对象,然后在需要共享的组件中引入并使用。

javascript">// mixins.js  
export default {  
  data() {  
    return {  
      message: 'Hello from mixins!',
      message2: '123123'
    }  
  },  
  methods: {  
    showMessage() {  
      console.log(this.message)  
    }  
  }  
}  
  
// 组件中使用mixins  
import myMixin from './mixins'  
  
export default {  
  mixins: [myMixin],  
  mounted() {  
    this.showMessage()  
    console.log(this.message2) // 123123
  }  
}

http://www.niftyadmin.cn/n/5537038.html

相关文章

【等保2.0是什么意思?等保2.0的基本要求有哪些? 】

一、等保2.0是什么意思&#xff1f; 等保2.0又称“网络安全等级保护2.0”体系&#xff0c;它是国家的一项基本国策和基本制度。在1.0版本的基础上&#xff0c;等级保护标准以主动防御为重点&#xff0c;由被动防守转向安全可信&#xff0c;动态感知&#xff0c;以及事前、事中…

《昇思25天学习打卡营第7天|函数式自动微分》

文章目录 今日所学&#xff1a;一、函数与计算图二、微分函数与梯度计算三、Stop Gradient四、Auxiliary data五、神经网络梯度计算总结 今日所学&#xff1a; 今天我学习了神经网络训练的核心原理&#xff0c;主要是反向传播算法。这个过程包括将模型预测值&#xff08;logit…

【抽代复习笔记】25-群(十九):一个关于循环群的重要定理以及三道证明例题

定理&#xff1a;G (a)是n阶循环群&#xff0c;则&#xff1a; &#xff08;1&#xff09;|a^r| n/(r,n)&#xff08;(r,n)是r和n的最大公因数&#xff09;&#xff1b; &#xff08;2&#xff09;当(r,n) 1时&#xff0c;a^r也是一个生成元&#xff1b; &#xff08;3&a…

第二十九天 第八章 贪心算法 part03 134. 加油站 135. 分发糖果 860.柠檬水找零 406.根据身高重建队列

134. 加油站 两种情况讨论&#xff0c;(容量-消耗量)的累加和小于0时不可环绕一周&#xff0c;反之即可&#xff0c;同时如果当前容量-消耗量小于0&#xff0c;那么当前加油站也不是加油站&#xff0c;往后推一站&#xff0c;但是我们一定能找到一个加油站作为开始加油站环绕…

字节跳动 AML 前端 一面

时长55mins 1. 自我介绍 1. 怎么接触的前端&#xff1f;学了多久&#xff1f; 1. 问项目 1. 为什么要做组件库&#xff1f; 1. 问到我的组件库和AntD之类的有什么区别&#xff0c;我说区别可能就是我的功能更少&#xff1f;hhhh 1. 设计一个组件的思路&#x…

LeetCode:3047. 求交集区域内的最大正方形面积(Java 枚举)

目录 3047. 求交集区域内的最大正方形面积 题目描述&#xff1a; 原理思路&#xff1a; 3047. 求交集区域内的最大正方形面积 题目描述&#xff1a; 在二维平面上存在 n 个矩形。给你两个下标从 0 开始的二维整数数组 bottomLeft 和 topRight&#xff0c;两个数组的大小都是…

(PADS学习)第三章:PCB基础知识 第四部分

第三章&#xff1a;PCB基础知识 五、PCB设计流程创建新设计流程布局设计电路分类通用器件布局器件布局注意事项时钟布局注意事项以太网布局注意事项光口布局注意事项滤波器件布局注意事项 布局拓扑设计点对点拓扑星型拓扑远端簇拓扑菊花链拓扑fly-by拓扑T型拓扑 叠层设计叠层设…

项目中上传功能过段时间就报错,解决方案

实际项目中&#xff0c;发现过段时间上传功能就报错&#xff0c;报错如下&#xff1a; 排查问题&#xff1a; 在服务器的 /tmp目录下发现并没有 /tomcat目录&#xff0c;也就验证了上面找不到这个文件的报错 那么这个临时给tomcat的上传目录怎么就没有了呢&#xff1f; 其实临…