vue2 中的 global

        在Vue中,我们可以通过使用全局变量来方便地在组件之间共享数据和方法。这些全局变量和方法都可以通过Vue对象来访问,所以我们也称之为Vue全局变量或者Vue全局方法。Vue中的全局变量和方法通常被用在多个组件之间需要共享数据或者方法的场景中,因为在Vue的组件中,我们通常是不推荐直接访问其他组件的数据或者方法。

        在Vue中,我们可以使用Vue对象的方法,来创建全局变量和方法。Vue.prototype是Vue的原型对象,我们可以在Vue.prototype上添加属性和方法,这些属性和方法会被所有Vue实例继承,也就是变成了全局变量和方法。

// 创建全局变量
Vue.prototype.$globalData = {
userInfo: {
name: 'John',
age: 20
}
}
// 创建全局方法
Vue.prototype.$globalFunc = function() {
console.log('Hello world')
}

        上面的代码中,$globalData是一个全局变量,$globalFunc是一个全局方法,它们都被添加到了Vue.prototype中。

        在使用这些全局变量和方法时,我们可以直接在组件中使用this.$globalData和this.$globalFunc来访问和调用它们。

export default {
mounted() {
console.log(this.$globalData.userInfo)
this.$globalFunc()
}
}

        另外,在Vue中,我们还可以使用Vue.mixin来创建全局混入,它可以让我们把一些常用的逻辑和代码封装起来,然后在所有组件中共享这些逻辑和代码。全局混入是针对组件而言的,使用它可以在多个组件之间共享代码。使用全局混入之前,我们需要定义一个混入对象,它可以包含一些钩子函数、方法、计算属性等。

// 定义一个全局混入
const myMixin = {
created() {
console.log('Mixin created')
},
methods: {
myMethod() {
console.log('Mixin method')
}
}
}
// 使用全局混入
Vue.mixin(myMixin)

        通过以上的代码,我们就可以在所有组件中使用myMethod这个方法,同时可以在所有组件的created钩子函数中输出'Mixin created'。

        需要注意的是,全局混入可以被局部混入覆盖掉,如果在某个组件中使用了与全局混入同名的钩子函数、方法、计算属性等,则该组件中的同名属性会覆盖掉全局混入的同名属性。

        以上就是Vue中的全局变量和方法的详细介绍,全局变量和方法可以让我们在多个组件之间共享数据和方法,同时全局混入也能让我们方便地共享逻辑和代码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值