vue3 第二十三节(全局属性方法应用)

vue2 与 vue3 的全局属性使用方法区别 1、globalProperties getcurrentinstace vue3 中已经移除对外暴露 getcurrentinstace,建议使用下面两种 2、provide | inject 3、mitt 事件总线程

1、vue2 通过 prototype 实例上挂载属性/方法,用于全局调用

javascript 复制代码
// main.js
import Vue from 'vue'
import App from './App.vue'
Vue.prototype.$message = '测试'
Vue.mount('#app',App')
javascript 复制代码
// 使用
methods:{
  test(){
    // 直接通过 this.$message 即可实现调用
    console.log(this.$message)
  }
}

2、vue3 中建议通过 provide | inject 挂载全局属性/方法

javascript 复制代码
// main.js

import { createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)
app.config.globalProperties.$message = '测试' // 这种方案vue3中已不建议使用
app.provide('message', '测试')
app.mount('#app')

3.1、通过 provide | inject 挂载全局属性/方法 建议使用

main.ts 中 通过全局依赖,如:app.provide('message', '测试') 这样即可在组件中通过 inject 获取到全局属性;

javascript 复制代码
<script setup>
const message = inject('message')
console.log(message) // 测试
</script>

更多关于provide() | inject() 的应用请查看组件之间通讯

3.2、通过globalProperties 挂载全局属性/方法 不建议使用

该属性发现在 vue3 的api文档中已经无法搜索到,已被隐藏,不建议使用app.config.globalProperties定义的全局变量不支持双向绑定,只是声明了一个全局的变量

javascript 复制代码
// main.ts
app.config.globalProperties.$message = '测试'
javascript 复制代码
使用时
<script setup>
import { getcurrentInstance } from 'vue'
getcurrentInstance.appContext.config.globalProperties.$message // 测试
</script>

3.3、事件总线 mitt() 不建议使用

javascript 复制代码
 yarn add mitt
javascript 复制代码
 // main.ts
 import mitt from "mitt"
 const Mitt = mitt()
 // 声明
 declare module 'vue'{
  export interface ComponentCustomProperties{
    $Bus: typeof Mitt
  }
}
 app.config.globalProperties.$Bus = Mitt

使用时候 使用emit()派发事件 on()接受事件 off()事件移除 clear()情况所有

javascript 复制代码
<script setup>
import {getCurrentInstance} from "vue"
const instance = getCurrentInstance().appContext.config.globalProperties
// 派发事件
instance.proxy.$Bus.emit("on-changeParams","修改参数")
// 监听事件

instance.proxy.$Bus.on("on-changeParams",(params) => {
  console.log('--params-')
})
// 关闭事件
instance.proxy.$Bus.off("on-changeParams",(params) => {
  console.log('--params-')
})
//清空所有监听
instance.all.clear();
</script>

vue3 中 3.3版本以上 组合式 API 中建议 使用 provide() | inject() 依赖注入的方法进行全局属性方法挂载

相关推荐
郑州光合科技余经理21 小时前
海外O2O系统源码剖析:多语言、多货币架构设计与二次开发实践
java·开发语言·前端·小程序·系统架构·uni-app·php
arvin_xiaoting1 天前
OpenClaw学习总结_I_核心架构_8:SessionPruning详解
前端·chrome·学习·系统架构·ai agent·openclaw·sessionpruning
工程师老罗1 天前
Image(图像)的用法
java·前端·javascript
swipe1 天前
把 JavaScript 原型讲透:从 `[[Prototype]]`、`prototype` 到 `constructor` 的完整心智模型
前端·javascript·面试
问道飞鱼1 天前
【前端知识】React 组件生命周期:从底层原理到实践场景
前端·react.js·前端框架·生命周期
CHU7290351 天前
定制专属美丽时刻:美容预约商城小程序的贴心设计
前端·小程序
浩~~1 天前
反射型XSS注入
前端·xss
AwesomeDevin1 天前
AI时代,我们的任务不应沉溺于与 AI 聊天,🤔 从“对话式编程”迈向“数字软件工厂”
前端·后端·架构
harrain1 天前
antvG2折线图和区间range标记同时绘制
前端·javascript·vue.js·antv·g2
德育处主任Pro1 天前
从重复搭建到高效生产,RollCode的H5开发新范式
前端