vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > Vue通过Vue.prototype定义原型属性实现全局变量

Vue如何通过Vue.prototype定义原型属性实现全局变量

作者:王小二(海阔天空)

在Vue.js开发中,通过原型属性为Vue实例添加全局变量是一种常见做法,使用$前缀命名,可以避免与组件内部的数据、方法或计算属性产生命名冲突,这种方式简单有效,确保了变量在所有Vue实例中的可用性,同时保持全局作用域的整洁

Vue通过Vue.prototype定义原型属性实现全局变量

如果需要设置全局变量,但不想污染全局作用域。

这种情况下

可以通过在main.js中,Vue实例化的代码里通过添加了原型属性实现全局变量,使其在每个 Vue 的实例中可用。

Vue.prototype.$appName = 'My App'

这样 $ appName 就在所有的 Vue 实例中可用了,甚至在实例被创建之前就可以。

如果我们运行下述代码

则控制台会打印出 My App。

new Vue({
  beforeCreate: function () {
    console.log(this.$appName)
  }
})

假如我们在main.js中通过如下方式定义原型属性

运行下述代码,则控制台会打印什么呢?

Vue.prototype.appName = 'My App'

new Vue({
  data: {
    appName: 'The name of some other app'
  },
  beforeCreate: function () {
    //父类中的属性
    console.log(this.appName)
  },
  created: function () {
    //子类重写的属性
    console.log(this.appName)
  }
})

控制台日志中会先出现 “My App”

然后出现 “The name of some other app”

因为 this.appName 在实例被创建之后被 data 覆写了

我们通过 $ 为实例属性设置作用域来避免这种事情发生。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文