vuex:
1、vuex的状态存储是响应式的。当Vue组件从store中读取状态的时候,若store中的状态发生变化,相应的组件也会得到更新
2、不能直接改变store中的状态,改变store状态的唯一途径就是显式的提交mutation(使用commit)
步骤:
1、安装Vuex
2、创建一个store,提供一个厨师state对象和一些mutation
// 如果在模块化构建系统中,请确保在开头调用了 Vue.use(Vuex)
const store = new Vuex.Store({
state: {
count: 0
},
mutations: {
add(state) {
state.count++
}
}
})
3、通过 store.state 来获取状态对象,通过 store.commit 方法触发状态变更
console.log(store.state.count)// => 0
store.commit('add')
console.log(store.state.count)// => 1
mapState 辅助函数
当一个组件需要获取多个状态的时候,使用mapState辅助函数就不用一个个引入了
import { mapState } from 'vuex'
export default {
computed:mapState ({
count:state => state.count
})
}