背景
考虑以下非常基本的插件:
import SomeObject from "./SomeObject";
/**
* Some Cool Plugin...
*/
export default {
install(Vue){
Vue.prototype.$someObject = Vue.observable(SomeObject);
}
}
上面的目的是在我的应用程序中注册一个反应性的对象。
问题与疑问
Vue.prototype.$someObject包含某些需要watched在全局级别而不是组件级别上的属性。
有没有办法在installVue 插件的方法中将观察者附加到 Vue 实例?
请注意,我不是在寻找以下答案,我已经知道这是可以做到的,但它违背了将代码分成插件的意义。全局混合也不够......
watch: {
'$someObject.foo': {
handler(value) {
console.log(value);
}
}
}
我试过的
根据此处概述的文档,我假设我可以按照以下方式做一些事情:
export default {
install(Vue){
Vue.prototype.$someObject = Vue.observable(SomeObject);
// I have tried all of the following:
Vue.watch(Vue.prototype.$someObject.foo, value => { console.log(value) });
Vue.$watch(Vue.prototype.$someObject.foo, value => { console.log(value) });
Vue.prototype.watch(Vue.prototype.$someObject.foo, value => { console.log(value) });
Vue.prototype.$watch(Vue.prototype.$someObject.foo, value => { console.log(value) });
Vue.watch(Vue.$someObject.foo, value => { console.log(value) });
Vue.$watch(Vue.$someObject.foo, value => { console.log(value) });
Vue.prototype.watch(Vue.$someObject.foo, value => { console.log(value) });
Vue.prototype.$watch(Vue.$someObject.foo, value => { console.log(value) });
}
}
慕容708150
相关分类