Vuex的一点总结

Vuex流程

State

import { mapState } from 'vuex'
computed: {...mapState(['']) }

this.$store.state

Getter

接受 state 作为其第一个参数,接受其他 getter 作为第二个参数

// 通过属性访问
getters: {
	getterName: (state, getters) => {
		return
	}
}
store.getters

// 通过方法访问
getters: {
	getterName: (state) => (id) => {
		return
	}
}
store.getters.getterName(props)

computed: {...mapGetters(['']) }

Mutation

// 定义
mutations: {
	increment(state) {
		// 变更state状态
	}
}
store.commit({
  type: 'increment',
  prop: 10
})

methods: {...mapMutations([''])}
this.$store.commit('')

Action

Action 提交的 mutation,而不是直接变更状态,可以包含异步操作

const store = new Vuex.Store({
	state: {
		count: 0
	},
	mutations: {
		increment(state) {
			state.count++
		}
	},
	actions: {
		increment(context) {
			context.commit('increment')
		}
	}
})
// context 对象不是 store 实例本身

methods: {...mapActions(['']) }
// 这里返回一个 Promise ,可以配合 async / await 使用
store.dispatch('actionA')

Module

// 模块内部的 mutation 和 getter,接收的第一个参数是模块的局部状态对象
const moduleA = {
	state: {}
}

const store = new Vuex.Store({
	modules: {
		a: moduleA
	}
})
// 启用命名空间
modules: { account: { namespaced: true} }

其他

  • 实现双向绑定:

    1. dom 事件监听
    
    computed: {
    ...mapState({
    	message: state => state.obj.message
    })
    },
    methods: {
    	updateMessage(e) {
    		this.$store.commit('updateMessage', e.target.value)
    	}
    }
    
    1. computedsetter
    
    computed: {
    computed: {
    	message: {
    		get() {
    			return this.$store.state.obj.message
    		},
    		set(value) {
    			this.$store.commit('updateMessage', value)
    		}
    	}
    }
    
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值