Vuex—简介+简单使用

## Vuex

### 1.概念

在Vue中实现集中式状态(数据)管理的一个Vue插件,对vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信。

State里面可以保存很多的数据

Actions+Mutations+States=> vuex

Dispatch 里面需要传两个参数:1.动作 2.参数

Actions里面保存了多组 name,function

function里自己调用Commit(‘name’,参数 )

Mutations里 有很多对象 name,function,还有State和参数

写代码之后,会自动进行Mutate

Action可以跟后端数据库连接(Ajax)

Vue Component可以直接调用Commit直接到Mutations

有一个store管理

### 2.何时使用?

多个组件需要共享数据时

### 3.搭建vuex环境

1. 创建文件:```src/store/index.js```

```js

  //引入Vue核心库
   import Vue from 'vue'
   //引入Vuex
   import Vuex from 'vuex'
   //应用Vuex插件
   Vue.use(Vuex)
   
   //准备actions对象——响应组件中用户的动作
   const actions = {}
   //准备mutations对象——修改state中的数据
   const mutations = {}
   //准备state对象——保存具体的数据
   const state = {}
   
   //创建并暴露store
   export default new Vuex.Store({
      actions,
      mutations,
      state
   })
   ```

2. 在```main.js```中创建vm时传入```store```配置项

```js

  //引入store
   import store from './store'
   ......
   
   //创建vm
   new Vue({
      el:'#app',
      render: h => h(App),
      store
   })

### 4.基本使用

1. 初始化数据、配置```actions```、配置```mutations```,操作文件```store.js```

```js

 //引入Vue核心库
   import Vue from 'vue'
   //引入Vuex
   import Vuex from 'vuex'
   //引用Vuex
   Vue.use(Vuex)
   
   const actions = {
       //响应组件中加的动作
      jia(context,value){
         // console.log('actions中的jia被调用了',miniStore,value)
         context.commit('JIA',value)
      },
   }
   
   const mutations = {
       //执行加
      JIA(state,value){
         // console.log('mutations中的JIA被调用了',state,value)
         state.sum += value
      }
   }
   
   //初始化数据
   const state = {
      sum:0
   }
   
   //创建并暴露store
   export default new Vuex.Store({
      actions,
      mutations,
      state,
   })

2. 组件中读取vuex中的数据:```$store.state.sum```

3. 组件中修改vuex中的数据:```$store.dispatch('action中的方法名',数据)``` 或 ```$store.commit('mutations中的方法名',数据)```

> 备注:若没有网络请求或其他业务逻辑,组件中也可以越过actions,即不写```dispatch```,直接编写```commit```

### 5.getters的使用

1. 概念:当state中的数据需要经过加工后再使用时,可以使用getters加工。

2. 在```store.js```中追加```getters```配置

```js

  const getters = {
      bigSum(state){
         return state.sum * 10
      }
   }
   
   //创建并暴露store
   export default new Vuex.Store({
      ......
      getters
   })
   ```

3. 组件中读取数据:```$store.getters.bigSum```

### 6.四个map方法的使用

1. <strong>mapState方法:</strong>用于帮助我们映射```state```中的数据为计算属性

```js

  computed: {
       //借助mapState生成计算属性:sum、school、subject(对象写法)
        ...mapState({sum:'sum',school:'school',subject:'subject'}),
           
       //借助mapState生成计算属性:sum、school、subject(数组写法)
       ...mapState(['sum','school','subject']),
  },

```

2. <strong>mapGetters方法:</strong>用于帮助我们映射```getters```中的数据为计算属性

```js

  computed: {
       //借助mapGetters生成计算属性:bigSum(对象写法)
       ...mapGetters({bigSum:'bigSum'}),
  
       //借助mapGetters生成计算属性:bigSum(数组写法)
       ...mapGetters(['bigSum'])
  },

```

3. <strong>mapActions方法:</strong>用于帮助我们生成与```actions```对话的方法,即:包含```$store.dispatch(xxx)```的函数

```js

  methods:{
       //靠mapActions生成:incrementOdd、incrementWait(对象形式)
       ...mapActions({incrementOdd:'jiaOdd',incrementWait:'jiaWait'})
  
       //靠mapActions生成:incrementOdd、incrementWait(数组形式)
       ...mapActions(['jiaOdd','jiaWait'])
  }

```

4. <strong>mapMutations方法:</strong>用于帮助我们生成与```mutations```对话的方法,即:包含```$store.commit(xxx)```的函数

```js

  methods:{
       //靠mapActions生成:increment、decrement(对象形式)
       ...mapMutations({increment:'JIA',decrement:'JIAN'}),
      
       //靠mapMutations生成:JIA、JIAN(对象形式)
       ...mapMutations(['JIA','JIAN']),
  }

```

> 备注:mapActions与mapMutations使用时,若需要传递参数需要:在模板中绑定事件时传递好参数,否则参数是事件对象。

### 7.模块化+命名空间

1. 目的:让代码更好维护,让多种数据分类更加明确。

2. 修改```store.js```

```javascript

   const countAbout = {
     namespaced:true,//开启命名空间
     state:{x:1},
     mutations: { ... },
     actions: { ... },
     getters: {
       bigSum(state){
          return state.sum * 10
      }
    }
  }
  
   const personAbout = {
     namespaced:true,//开启命名空间
     state:{ ... },
     mutations: { ... },
     actions: { ... }
  }
  
   const store = new Vuex.Store({
     modules: {
       countAbout,
       personAbout
    }
  })

```

3. 开启命名空间后,组件中读取state数据:

```js

   //方式一:自己直接读取
   this.$store.state.personAbout.list
   //方式二:借助mapState读取:
   ...mapState('countAbout',['sum','school','subject']),

```

4. 开启命名空间后,组件中读取getters数据:

```js

   //方式一:自己直接读取
   this.$store.getters['personAbout/firstPersonName']
   //方式二:借助mapGetters读取:
   ...mapGetters('countAbout',['bigSum'])

```

5. 开启命名空间后,组件中调用dispatch

```js

   //方式一:自己直接dispatch
   this.$store.dispatch('personAbout/addPersonWang',person)
   //方式二:借助mapActions:
   ...mapActions('countAbout',{incrementOdd:'jiaOdd',incrementWait:'jiaWait'})

```

6. 开启命名空间后,组件中调用commit

```js

   //方式一:自己直接commit
   this.$store.commit('personAbout/ADD_PERSON',person)
   //方式二:借助mapMutations:
   ...mapMutations('countAbout',{increment:'JIA',decrement:'JIAN'}),

### 4.基本使用代码详情

Count.vue:


<template>
    <div>
        <h1>当前求和为:{{ $store.state.sum }}</h1>
        <select v-model.number="n">
            <option value="1">1</option>
            <option value="2">2</option>
            <option value="3">3</option>
        </select>
        <button @click="increment">+</button>
        <button @click="decrement">-</button>
        <button @click="incrementOdd">当前求和为奇数再加</button>
        <button @click="incrementWait">等一等再加</button>
    </div>
</template>
<script>
    export default {
        name:'Count',
        data() {
            return {
                n:1, //用户选择的数字
                
            }
        },
        methods: {
            //commit可以直接跟mutation对话
            increment(){
                this.$store.commit('JIA',this.n)
            },
            decrement(){
                this.$store.commit('JIAN',this.n)
            },
            incrementOdd(){
                this.$store.dispatch('jiaOdd',this.n)
            },
            incrementWait(){
                this.$store.dispatch('jiaWait',this.n)
            },
        },
    }
</script>
<style lang="css">
    button{
        margin-left: 5px;
    }
</style>
Store/index.js:


//该文件用于创建Vuex中最为核心的store
//引入Vue
import Vue from "vue";
//引入Vuex
import Vuex from 'vuex'
//使用了之后,都可以使用store配置项
Vue.use(Vuex)
//准备actions——用于响应组件中的动作
const actions={
    //context里面包括了一些vm认为你会用到的对象
    // jia(context,value){
    //     context.commit('JIA',value)
    // },
    // jian(context,value){
    //     context.commit('JIAN',value)
    // },
    jiaOdd(context,value){
        if(context.state.sum%2){
            context.commit('JIA',value)
        }
    },
    jiaWait(context,value){
        setTimeout(()=>{
            context.commit('JIA',value)
        },500)
    }
}
//准备mutations——用于操作数据(state)
const mutations={
    //大写可以区分
    JIA(state,value){
        state.sum+=value
    },
    JIAN(state,value){
        state.sum-=value
    }
}
//准备state——用于存储数据
const state={
    sum:0 //当前的和
}
//创建store
export default new Vuex.Store({
    actions,
    mutations,
    state,
})
//导出(暴露)store
//export default store
Main.js:


//引入Vue
import Vue from 'vue'
//引入App
import App from './App.vue'
//引入插件
import vueResource from 'vue-resource'
//引入store
import store from './store/index'
//关闭Vue的生产提示
Vue.config.productionTip = false
//使用插件
Vue.use(vueResource)

//创建vm
new Vue({
    el:'#app',
    render: h => h(App),
    store,
    beforeCreate() {
        Vue.prototype.$bus = this
    }
})

### 5.getters的使用代码详情

Count.vue:


<template>
    <div>
        <h1>当前求和为:{{ $store.state.sum }}</h1>
        <h3>当前求和放大10倍为:{{$store.getters.bigSum}}</h3>
        <select v-model.number="n">
            <option value="1">1</option>
            <option value="2">2</option>
            <option value="3">3</option>
        </select>
        <button @click="increment">+</button>
        <button @click="decrement">-</button>
        <button @click="incrementOdd">当前求和为奇数再加</button>
        <button @click="incrementWait">等一等再加</button>
    </div>
</template>
<script>
    export default {
        name:'Count',
        data() {
            return {
                n:1, //用户选择的数字
                
            }
        },
        methods: {
            //commit可以直接跟mutation对话
            increment(){
                this.$store.commit('JIA',this.n)
            },
            decrement(){
                this.$store.commit('JIAN',this.n)
            },
            incrementOdd(){
                this.$store.dispatch('jiaOdd',this.n)
            },
            incrementWait(){
                this.$store.dispatch('jiaWait',this.n)
            },
        },
    }
</script>
<style lang="css">
    button{
        margin-left: 5px;
    }
</style>
Store/index.js:


//该文件用于创建Vuex中最为核心的store
//引入Vue
import Vue from "vue";
//引入Vuex
import Vuex from 'vuex'
//使用了之后,都可以使用store配置项
Vue.use(Vuex)
//准备actions——用于响应组件中的动作
const actions={
    //context里面包括了一些vm认为你会用到的对象
    // jia(context,value){
    //     context.commit('JIA',value)
    // },
    // jian(context,value){
    //     context.commit('JIAN',value)
    // },
    jiaOdd(context,value){
        if(context.state.sum%2){
            context.commit('JIA',value)
        }
    },
    jiaWait(context,value){
        setTimeout(()=>{
            context.commit('JIA',value)
        },500)
    }
}
//准备mutations——用于操作数据(state)
const mutations={
    //大写可以区分
    JIA(state,value){
        state.sum+=value
    },
    JIAN(state,value){
        state.sum-=value
    }
}
//准备state——用于存储数据
const state={
    sum:0 //当前的和
}
//准备getters——用于将state中的数据进行加工
const getters = {
    bigSum(state){
        return state.sum*10
    }
}
//创建store
export default new Vuex.Store({
    actions,
    mutations,
    state,
    getters
})
//导出(暴露)store
//export default store

### 6.四个map方法的使用代码详情

mapState, mapGetters:
Count.vue:


<template>
    <div>
        <h1>当前求和为:{{ sum }}</h1>
        <h3>当前求和放大10倍为:{{bigSum}}</h3>
        <h3>我在{{  school }},学习:{{  subject }}</h3>
        <select v-model.number="n">
            <option value="1">1</option>
            <option value="2">2</option>
            <option value="3">3</option>
        </select>
        <button @click="increment">+</button>
        <button @click="decrement">-</button>
        <button @click="incrementOdd">当前求和为奇数再加</button>
        <button @click="incrementWait">等一等再加</button>
    </div>
</template>
<script>
    import {mapState, mapGetters} from 'vuex'
    export default {
        name:'Count',
        data() {
            return {
                n:1, //用户选择的数字
                
            }
        },
        computed:{
            //程序员亲自书写的代码
            // sum(){
            //  return this.$store.state.sum
            // }
            //1.借助mapState生成=>对象写法
            //mapState里面需要几组数据,方法名和去state里面找的data
            //...能够使mapState结果(返回值为数组)里的每一项展开放在computed数组里面
            //...mapState({sum:'sum',school:'school',subject:'subject'})
            //2.函数名与data值一样,可以用数组写法简写
            ...mapState(['sum','school','subject']),
            ...mapGetters(['bigSum'])
        },
        methods: {
            //commit可以直接跟mutation对话
            increment(){
                this.$store.commit('JIA',this.n)
            },
            decrement(){
                this.$store.commit('JIAN',this.n)
            },
            incrementOdd(){
                this.$store.dispatch('jiaOdd',this.n)
            },
            incrementWait(){
                this.$store.dispatch('jiaWait',this.n)
            },
        },
    }
</script>
<style lang="css">
    button{
        margin-left: 5px;
    }
</style>
mapMutations,mapActions:

<template>
    <div>
        <h1>当前求和为:{{ sum }}</h1>
        <h3>当前求和放大10倍为:{{bigSum}}</h3>
        <h3>我在{{  school }},学习:{{  subject }}</h3>
        <select v-model.number="n">
            <option value="1">1</option>
            <option value="2">2</option>
            <option value="3">3</option>
        </select>
        <button @click="increment(n)">+</button>
        <button @click="decrement(n)">-</button>
        <button @click="incrementOdd(n)">当前求和为奇数再加</button>
        <button @click="incrementWait(n)">等一等再加</button>
    </div>
</template>
<script>
    import {mapState, mapGetters,mapMutations,mapActions} from 'vuex'
    export default {
        name:'Count',
        data() {
            return {
                n:1, //用户选择的数字
                
            }
        },
        computed:{
            ...mapState(['sum','school','subject']),
            ...mapGetters(['bigSum'])
        },
        methods: {
            //commit可以直接跟mutation对话
            // increment(){
            //  this.$store.commit('JIA',this.n)
            // },
            // decrement(){
            //  this.$store.commit('JIAN',this.n)
            // },
            //借助mapMutations生成对应的方法,方法中会调用commit方法,去联系mutation
            //1.对象写法
            ...mapMutations({increment:'JIA',decrement:'JIAN'}),
            //2.数组写法
            //函数名字也要修改
            //...mapMutations(['JIA','JIAN']),

            // incrementOdd(){
            //  this.$store.dispatch('jiaOdd',this.n)
            // },
            // incrementWait(){
            //  this.$store.dispatch('jiaWait',this.n)
            // },
            //借助mapActions生成对应的方法,方法中会调用diapath方法,去联系actions
            //1.对象写法
            ...mapActions({incrementOdd:'jiaOdd',incrementWait:'jiaWait'})
            //2.数组写法
        },
    }
</script>
<style lang="css">
    button{
        margin-left: 5px;
    }
</style>
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值