可以让一个对象变成响应式数据。在 Vue 内部就是用它来处理传递给 Vue 的 data 对象,或是在单文件组件中 data()
返回的对象。
var vm = new Vue({
data: {
count: 0
}
})
// 或在单文件组件中
export default {
data() {
return {
count: 0,
};
},
};
返回的对象可以直接用于渲染函数和计算属性内,并且会在发生变更时触发相应的更新。也可以作为最小化的跨组件状态存储器,用于简单的场景:
可以作为小型的状态管理器。
举例:
// store.js
import Vue from "vue";
const state = Vue.observable({
count: 0,
});
export default state;
<template>
<div>
<div>{{ count }}</div>
<button @click="handleClick">count自增</button>
</div>
</template>
<script>
import state from "./store.js";
export default {
computed: {
count() {
return state.count;
},
},
methods: {
handleClick() {
state.count++;
},
},
};
</script>
状态管理器需要的是:全局的响应式数据。
既然如此,也可以再创建一个 Vue 实例作为全局状态。比如:
// store.js
import Vue from "vue";
const state = new Vue({
data: {
count: 0,
},
});
export default state;
那和使用 Vue.observable()
创建出的全局状态,有什么区别呢?
new Vue()
本质上也是使用 Vue.observable()
创建的响应式数据。对比下二者包含哪些内容:
Vue.observable():
Vue 实例:
Vue 实例也有其他的用法,比如可以实现全局通信(数据和事件),参考 EventBus。
以上。