vuex新手进阶篇之改变state mutations的使用

 更新时间:2022年10月19日 15:04:45   作者:Jay丶千珏  
在vue的项目中不可避免的会使用到vuex用于数据的存储,下面这篇文章主要给大家介绍了关于vuex新手进阶篇之改变state mutations的使用,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下

紧接上篇文章,本篇文章讲vuex ,如何去改变state ,mutations的使用,我依然使用了vuex的modules

1. 设置改变state的mutations事件

index.js

dict.js

2.提交mutations事件(常用的两种方法)

<template>
  <div>
    <div>
      改变vuex index.js 下的state
      <div>
        {{ $store.state.userInfo.name + "---" + $store.state.userInfo.age }}
      </div>
      <div>
        <button @click="changeUserInfo">修改方式1</button>
      </div>
      <div>
        <button @click="changeUserInfo2">修改方式2</button>
      </div>
    </div>
    --------------------------------------------------
 
    <div>
      改变vuex index.js modules下的dict 下的state
      <div>
        {{ $store.state.dict.taskTypeDict }}
      </div>
      <div>
        <button @click="changeDict">修改方式1</button>
      </div>
      <div>
        <button @click="changeDict2">修改方式2</button>
      </div>
    </div>
  </div>
</template>
 
<script>
import { mapMutations } from "vuex"; //修改vuex state第二种方式,首先引入
export default {
  data() {
    return {};
  },
  methods: {
    // 修改方式1,提交mutations
    changeUserInfo() {
      let userInfo = { name: "uzi", age: 24 };
      //setUserInfo方法为你在vuex index.js 下的mutations下的注册的方法名称
      this.$store.commit("setUserInfo", userInfo);
    },
    // 修改方式2
    ...mapMutations(["setUserInfo"]), //把vuex index.js 下的mutations下的注册的方法名称写入
    changeUserInfo2() {
      let userInfo = { name: "kobe", age: 30 };
      this.setUserInfo(userInfo);
    },
    // ------------------------------------------------------------------
    changeDict() {
      let dict = "进行中";
      //   因为我们在modules下开启了命名空间,所以我们在调用dict下的Mutations时,需在前方加上空间名字
      this.$store.commit("dict/setTaskTypeDict", dict);
    },
    ...mapMutations({ setDict: "dict/setTaskTypeDict" }), //因为我们开辟了命名空间,故需要重写一个方法名,进行承接映射,注意此处不再是数组,而是一个对象
    changeDict2() {
      let dict = "已完成";
      this.setDict(dict);
    },
  },
};
</script>

注释本人认为已写清

总结

到此这篇关于vuex新手进阶篇之改变state mutations使用的文章就介绍到这了,更多相关vuex改变state mutations的使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue使用Three.js创建交互式3D场景的全过程

    Vue使用Three.js创建交互式3D场景的全过程

    在现代Web开发中,通过在页面中嵌入3D场景,可以为用户提供更加丰富和交互性的体验,Three.js是一款强大的3D JavaScript库,它简化了在浏览器中创建复杂3D场景的过程,本文将介绍如何在Vue中使用Three.js,创建一个简单的交互式3D场景,需要的朋友可以参考下
    2023-11-11
  • Vue组件二次封装的一些实用技巧总结

    Vue组件二次封装的一些实用技巧总结

    我们在做项目经常会遇到组件功能不能满足业务需求的时候,这时候需要在原有的组件上进行二次封装,下面这篇文章主要给大家介绍了关于Vue组件二次封装的一些实用技巧,需要的朋友可以参考下
    2022-04-04
  • 在vue中写jsx的几种方式

    在vue中写jsx的几种方式

    本文主要介绍了在vue中写jsx的几种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 详解vuex之store源码简单解析

    详解vuex之store源码简单解析

    这篇文章主要介绍了详解vuex之store源码简单解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • 如何使用Vuex+Vue.js构建单页应用

    如何使用Vuex+Vue.js构建单页应用

    这篇文章主要教大家如何使用Vuex+Vue.js构建单页应用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • vue实现直连mysql的方法步骤

    vue实现直连mysql的方法步骤

    Vue.js通常运行在浏览器环境,而浏览器不允许直接与MySQL数据库进行连接,本文主要介绍了vue实现直连mysql的方法步骤,感兴趣的可以了解一下
    2024-11-11
  • vue路由缓存的几种实现方式小结

    vue路由缓存的几种实现方式小结

    这篇文章主要介绍了vue路由缓存的几种实现方式,结合实例形式详细分析了vue.js路由缓存常见实现方式、使用技巧与操作注意事项,需要的朋友可以参考下
    2020-02-02
  • Vue动态类的几种使用方法总结

    Vue动态类的几种使用方法总结

    这篇文章主要介绍了Vue动态类的几种使用方法总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • Vue项目利用axios请求接口下载excel

    Vue项目利用axios请求接口下载excel

    这篇文章主要为大家详细介绍了Vue项目利用axios请求接口下载excel,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • el-select 下拉框全选、多选的几种方式组件示例详解

    el-select 下拉框全选、多选的几种方式组件示例详解

    这篇文章主要介绍了el-select 下拉框全选、多选的几种方式组件示例详解,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-12-12

最新评论