Vue.prototype的应用——main.js中设置的全局变量,不想污染全局作用域
vue知识
·
Vue.prototype的应用——main.js中设置的全局变量,不想污染全局作用域
如果需要设置全局变量,在main.js中,Vue实例化的代码里添加。
不想污染全局作用域。这种情况下,你可以通过在原型上定义它们使其在每个Vue实例中可用。
src/main.js
Vue.prototype.$http = axios;
这样 $http 就在所有Vue实例中可用了,甚至在实例被创建之前就可以用。 如果我们运行:
new Vue({
beforeCreate: function() {
console.log(this.$http)
}
});
则控制台会打印出:
“为什么 http 要以 $
开头? 这很重要吗? 他会怎样?”
$ 是在Vue 所有实例中都可用的属性的一个简单约定。这样做会避免与已被定义的数据、方法、计算属性产生冲突。
“你指的冲突是什么意思?”
好问题!如果你写成:
Vue.prototype.http = axios
下面的代码输出什么呢?
new Vue({
data: {
http: '123456'
},
beforeCreate: function() {
console.log(this.http)
},
created: function() {
console.log(this.http)
}
});
控制台显示顺序为
后出现’123456’,因为 this.http 在实例创建之后被data覆写了。我们通过 $ 为实例属性设置 作用域 避免这种事情发生。你可以根据你的喜好使用自己的约定,诸如 $_http 或 Ωhttp,来避免和插件或未来的插件相冲突。
更多推荐
已为社区贡献72条内容
所有评论(0)