Vuex技巧

安装vuex依赖

 

npm i vuex -S

导入vuex 包

 

import Vuex from 'vuex'
Vue.use(Vuex)

创建 store 对象

 

const store=new Vuex.Store({
        // state 中存放的就是全局共享的数据
        state:{count:0}
  })

将 store 对象挂载到 Vue 实例中

 

new Vue({
    el:'#app',
    render:h => h(app),
    router,
    //将创建的共享数据对象,挂载到 Vue 实例中
    //所有的组件,就可以直接从 store 中获取全局的数据了
    store
})

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

 

this.$store.state.全局数据名称
//如果在模板中访问 不需要写this

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

 

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

通过此函数将当前组件需要的全局数据,映射为当前组件的computed计算属性

 

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

在模板调用直接写 count

Mutation

注意:在组件中引入使用vuex全局数据时,不要直接修改vuex里的原始数据

Mutation用于变更 Store中的数据
1.只能通过mutation变更Store数据,不可以直接操作Store中的数据
2.通过这种方式操作起来虽然繁琐一些,但是可以集中监控所有数据变化

 

  //定义 Mutations
const store = new Vuex.Store({
  state:{
      count : 0
  },
  mutations : {
      add(state) {
            //变更状态
            state.count++
      }
  }
})

 

//使用mutations
  methods:{
      fn(){
          //触发 mutations 的第一种方式
          //commit 的作用就是 调用某个 mutation 函数
           this.$store.commit('add')    
  }
}

调用 mutations 并且 传递参数

 

  //定义 Mutations
const store = new Vuex.Store({
  state:{
      count : 0
  },
  mutations : {
      add(state,step) {
            //变更状态
            state.count += step
      }
  }
})

 

//使用mutations
  methods:{
      fn(){
          //调用 commit 函数时 携带参数
           this.$store.commit('add',3)    
  }
}

提交 mutation 的另一种方式是直接使用包含 type 属性的对象

 

this.store.commit({
  type: 'increment',
  amount: 10
})

action

如果需要异步变更数据 就需要先在组件中使用 $store.dispatch('fn',type)调用 actions,actions 执行完异步操作或得到数据后 再使用 cxt.commit 调用 mutations里的方法更改数据

 

  actions:{
    fn(cxt,type){
        //第一个参数是执行上下文 类似与this 第二个参数是传参
        //actions 需要执行异步修改数据时
          settimeout(()=>{
                 let data = 5
              cxt.commit('getData',data)       
         },1000)
  },
 mutations:{
      getData(state,data){
          state.data = data
      }
  }

}

getters

getters 类似于计算属性
getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算。

 

  getters: {
    doneTodos: state => {
      return state.todos.filter(todo => todo.done)
    }
  }

使用时直接

 

$store.getters.函数名

modules 模块

当我们开发中大型项目时 会有相当多的数据需要传递时 就需要考虑模块化

 

//首先在配置 new Vuex.Store实例的文件中 引入 拆分后的 模块
import user from '@/store/user'
//之后在 new Vuex.Store实例的modules中配置
  new Vue.Store({
        state:{},
        actions:{},
        mutations:{},
        getters:{},
        modules:{
          user
    }
 })

注意 分模块 哪怕已经拆分成一个个的js文件也需要配置 namespaced:true 命名空间
namespaced这是用于解决不同模块的命名冲突问题

 

 let user = {
   namespaced:true,
  state: {
    userName: '华子',
  },
  actions: {},
}
export default user

vuex中的映射函数 (辅助函数)

当一个组件需要获取多个状态时候,将这些状态都声明为计算属性会有些重复和冗余。为了解决这个问题,我们可以使用 mapState 辅助函数帮助我们生成计算属性,让你少按几次键

 

//首先按需引入
import {mapState,mapActions,mapMutations,mapGetters} from 'vuex'
//mapState与mapGetters写在computed中 mapActions与mapMutations写在methods中
//都需要写在最上层
  export default {
  computed: {
//通过展开运算符 可以和别的计算属性 混用
    ...mapState({
      userName: (state) => state.user.userName,
    }),
 ...mapGetters({
      data: 'user/data',
    })
  },
//计算属性直接 {{userName}}使用即可
  methods: {
//在组件中引入映射函数的方法
     ...mapActions({
        changeNum:'user/changeNum'
      }),
     ...mapMutations({
        changeUserName:'user/changeUserName'
      }),
    ...mapMutations(['user/changeUserName',xx,xxx]),
//在组件的自定义函数内调用 映射函数 的方法
    change(){
      this.changeUserName('刘德华')
    },
 change(){
      this['user/changeUserName']('刘德华')
    },
    changenum(){
      this.changeNum(666)
    }
  },
};

直接在模板中使用映射函数的方法

 

<button @click="changeUserName('刘德华')"> 点击改名 </button>
<button @click="changeNum(666)"> 点击1s后更改数字 </button>



 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vuex中,commit用于触发mutations中的方法来改变state的数据。它是同步操作,用于处理那些不需要异步操作的数据改变。 具体的使用方式是通过this.$store.commit('mutations方法名', 值)来调用。其中,'mutations方法名'指的是定义在mutations对象中的方法名,用于更新state的数据,而值则是需要传递给该方法的参数。 使用commit改变state数据的写法可能会比较繁琐,因为每个数据改变都需要写一个对应的commit函数。这是因为Vuex遵循的是单向数据流的原则,即数据的改变必须通过commit方法来触发对应的mutations方法,以保持数据的一致性和可追溯性。 总结来说,通过commit方法可以同步地改变Vuex中的state数据,而且它是一个非常重要且必要的工具,用于遵循单向数据流的设计原则,确保数据的可靠性和可追溯性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [详解vuex commit保存数据技巧](https://download.csdn.net/download/weixin_38625048/14819005)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [vuex的commit](https://blog.csdn.net/u011565547/article/details/108830084)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值