zoukankan      html  css  js  c++  java
  • vuex的核心概念

    vuex的核心概念

    State

    State提供唯一的公共数据源, 所有共享的数据都要统放到Store的State中进行存储。

    //创建store数据源, 提供唯一公 共数据
    const store = new Vuex. Store ({
    	state:{ count: 0 }
    	})
    

    组件访问State中数据的第一种方式:

    this.$store. state.全局数据名称
    

    组件访问State中数据的第二种方式:

    // 1.从vuex 中按需导入mapState 函数
    import { mapState} from 'vuex'
    

    通过刚才导入的mapState函数,将当前组件需要的全局数据,映射为当前组件的computed计算属性:

    // 2.将全局数据,映射为当前组件的计算属性
    computed:
    . . .mapState([ 'count! ])
    }
    

    Mutation

    Mutation于变更Store中的数据。
    ①只能通过mutation变更Store数据,不可以直接操作Store中的数据。
    ②通过这种方式虽然操作起来稍微繁琐-些,但是可以集中监控所有数据的变化。

    // 定义Mutation
    const store = new Vuex. Store({
    	state: {
    	count: 0
    },
    mutations: {
    	add(state) {
    	//变更状态
    	state . count++
    })
    
    //触发mutation
    methods:{
    	handle1() {
    	//触发mutations 的第一种方式
    	this.$store . commit('add' )
    	}
    }
    

    可以在触发mutations时传递参数:

    //定义Mutation
    const store = new Vuex. store ( {
    	state: {
    		count: 0
    	},
    	mutations: {
    		addN(state, step) {
    		//变更状态:
    		state .count += step
    		}
    })
    
    //触发mutation
    methods: {
    	handle2() {
    	//在调用commit函数,
    	//触发mutations时携带参数
    		this.$store . commit('addN', 3)
    	}
    }
    

    this. $store.commit是触发mutations的第一种方式,触发mutations的第二种方式:

    // 1.从vuex 中按需导入mapMutations 函数
    import { mapMutations } from 'vuex'
    

    通过刚才导入的mapMutations函数,将需要的mutations函数,映射为当前组件的methods方法:

    // 2.将指定的mutations 函数,映射为当前组件的methods 函数
    methods :{
    ...mapMutations(['add', 'addN'])}
    

    Action

    触发actions异步任务时携带参数:

    //定义Action
    const store = new Vuex. Store ({
    //...省略其他代码
    	mutations: {
    		addN(state, step) {
    		state.count += step
    		}
    	},
    	actions: {
    		addNAsync(context, step) {
    			setTimeout( () => {
    			context .commit('addN', step)
    			}, 1000)
    		}
    	}
    })
    
    //触发Action
    methods:{
    	handle() {
    	//在调用dispatch函数,
    	//触发actions 时携带参数
    	this. $store .dispatch ( 'addNAsync', 5)
    	}
    }
    

    this. $store.dispatch0是触发actions的第一种方式, 触发actions的第二种方式:

    // 1.从vuex中按需导入mapActions 函数
    import { mapActions } from 'vuex '
    

    通过刚才导入的mapActions函数,将需要的actions函数,映射为当前组件的methods方法:

    // 2.将指定的actions 函数,映射为当前组件的methods 函数
    methods: {
    ...mapActions([ 'addASync','addNASync'])}
    

    Getter

    Getter用于对Store中的数据进行加工处理形成新的数据。
    ①Getter 可以对Store中已有的数据加工处理之后形成新的数据,类似Vue的计算属性。
    ②Store 中数据发生变化,Getter 的数据也会跟着变化。

    //定义Getter
    const store = new Vuex.store ({
    	state:{
    	count: 0
    	},
    		getters: {
    		showNum: state => {
    		return ' 当前最新的数量是[ '+ state.count +' ] '
    		}
    	}
    })
    

    使用getters 的第一种方式:

    this.$store.getters.名称
    

    使用getters的第二种方式:

    import  { mapGetters } from 'vuex '
    computed:{
    ...mapGettersT[ ' showNum'] )}
    
  • 相关阅读:
    Nginx入门
    Spring基础知识汇总 Java开发必看
    java ArrayList倒序
    1
    js event 的target 和currentTarget
    java 文件的写入和读取
    DOMContentLoaded与load的区别
    JS中先有Object还是先有Function?
    JSON.stringify的三个参数
    Java的泛型约束和限制
  • 原文地址:https://www.cnblogs.com/yxyc/p/14891020.html
Copyright © 2011-2022 走看看