Vuex原理图/环境配置手敲/求和案例(详解入门)

若尘 2022-05-20 18:25:27

 

1.Vuex环境搭建

三个步骤:

1.npm i vuex
//注意:(vue3只能安装npm i vuex@4)

//注意:(vue3只能安装npm i vuex@3)

//2.store文件夹使用Vue.use(Vuex)
//(1)src文件夹下创建 store文件夹

//(2)引入文件Vue 和 Vuex因为Vue.要使用Vuex

improt Vue from 'vue'

import Vuex from 'vuex'

Vue.use(Vuex)

//(3)准备好actions/mutations/state三个对象

const actions = {}

const mutations = {}

const state = {}

//(4)然后创建并暴露store

export default new Vuex.Store({

actions ,

mutations,

state,

})

3.在main.js中用全局使用store

//引入store

import Store from './store'

//new Vue实例中添加一个Store配置项

new Vue({

el:'#app',

render:h => h(App),

Store,

beforeCreate(){

Vue.prototype.$bue = this

}

})

4.components创建组件Count.vue

<template>
    <div>
    	<h2>当前求和为:4</h2>
        <select v-model.number='n'>
            //也可以通过v-bind:value控制字符串'1'改动时变成string数字
            <option value='1'>1</option>
            <option value='2'>2</option>
            <option value='3'>3</option>
        </select>
        <button @click='add'>+</button>
        <button @click='addDe'>-</button>
        <button @click='addOdd'>当前求和为奇数在加</button>
        <button @click='addWaite'>等一等在加</button>
    </div>
</template>
<script>
    export default {
        name:'Count',
        data() {
            return {
                n:1,
            }
        },
        methods:{
            add() {
                this.$store.commit('JIA',this.n)
            },
            addDe() {
                this.$store.commit('JIAN',this.n)
            },
            addOdd() {
                this.$store.dispatch('addOdd'.this.n)
            },
            addWaite() {
                this.$store.dispatch('addWaite'.this.n)
         },
    }
}
   </script>

5..在store文件夹中创建index.js中的准备好actions/mutations/state三个对象写上对应的响应/操作/存储更改内容

//准备actions服务员接受客人提的要求dispatch(要求)
const actions = {

​	addOdd(context,value) {

​	if(context.state.sum){context.$commit('JIA',value)}},

​	addWaite(context,value) {
    setTimeout(() =>{context.$commit('JIA',value)},500)
}},
// 准备mutations厨师操作数据按照条件变更   
const mutations = {

JIA(state,value) {state.sum += value},

JIAN(state,value) {state.sum -= value}

}

//准备state存储数据

const state = {

​	sum:0,

}

6.console.log(context)内容

 

7.console.log(state)内容

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

...全文
2474 回复 打赏 收藏 举报
写回复
回复
切换为时间正序
请发表友善的回复…
发表回复
相关推荐
发帖
CSDN 开源社区

1016

社区成员

本社区的主要目的是以分享开源项目的相关知识为主。
其他 其他
社区管理员
  • GitCode
  • XianxinMao
  • 茶陵後
加入社区
帖子事件
创建了帖子
2022-05-20 18:25
社区公告

GitCode能有效的将代码管理与线上练习以及线上评测打通,实现一站式学与练的教学管理环境。