京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

2024-11-2 22:33| 发布者: f5db4| 查看: 85| 评论: 0

摘要: 目次Vue通过Vue.prototype定义原型属性实现全局变量这种情况下假如我们运行下述代码假如我们在main.js中通过如下方式定义原型属性控制台日记中会先出现 “My App”总结Vue通过Vue.prototype定义原型属性实
目次

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

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

这种情况下

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

[code]Vue.prototype.$appName = 'My App'[/code]

这样 $ appName 就在全部的 Vue 实例中可用了,以致在实例被创建之前就可以。

假如我们运行下述代码

则控制台会打印出 My App。

[code]new Vue({ beforeCreate: function () { console.log(this.$appName) } })[/code]
  • 提问:上述代码中,为什么 appName 要以 $ 开头呢?
  • 回答:$ 是在 Vue 全部实例中都可用的属性的一个简朴约定。这样做会避免和已被定义的数据、方法、盘算属性产生冲突。

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

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

[code]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) } })[/code]

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

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

由于 this.appName 在实例被创建之后被 data 覆写了

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

总结

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


来源:https://www.jb51.net/javascript/328556yw7.htm
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
关闭

站长推荐上一条 /6 下一条

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2025-7-2 07:23 , Processed in 0.029643 second(s), 18 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

返回顶部