vue2备忘vuex

vue2备忘之vuex

准备

  • 配置——vue2需要vuex3
import Vue from "vue";
import Vuex, { Store } from "vuex"
import comA from "./comA.js"

Vue.use(Vuex)

const store = new Store({
})

export default store
  • 挂载到main.js
import Vue from 'vue'
import App from './App.vue'
import store from './store'

Vue.config.productionTip = false

new Vue({
  store,
  render: h => h(App),
}).$mount('#app')
  • 分模块后state、mutations、actions、getters的使用
const comA = {
    namespaced: true,
    state: () => {
        return {
            a: 1,
            b: 2,
        }
    },
    mutations: {
        add(state, value) {
            state.a += value
            state.b += value
        },
        dis(state, value) {
            state.a -= value
            state.b -= value
        },
    },
    actions: {
        exDis(ctx, value) {
            ctx.commit('dis', value)
        }
    },
    getters: {
        sum: (state) => {
            return state.a + state.b
        }
    },
}

export default comA
  • 将模块挂载index上
import Vue from "vue";
import Vuex, { Store } from "vuex"
import comA from "./comA.js"

Vue.use(Vuex)

const store = new Store({
    modules: {
        comA
    }
})

export default store

使用

  • state使用

$store.state.模块名.变量名

mapState(‘模块名’, [‘变量名’])

  • getters使用

$store.getters[“模块名/变量名”]

mapGetters(‘模块名’,[‘变量名’])

  • mutations使用

$store.commit(‘模块名/变量名’,传入的变量)

mapMutations(‘模块名’, [‘变量名’])

  • actions使用

$store.dispatch(‘模块名/变量名’,传入的变量)

mapActions(‘模块名’,[‘变量名’])

<template>
   <div>
      routerA
      <button @click="toB">toB</button>
      <h1>vuex</h1>
      <p>
         {{ $store.state.comA.a }} + {{ $store.state.comA.b }} = {{ $store.getters["comA/sum"] }}
         <button @click="$store.commit(`comA/add`,5)">+</button>
         <button @click="$store.dispatch(`comA/exDis`,5)">-</button>
      </p>
      <p>
         {{ a}}+{{ b }}={{ sum }}
         <button @click="add(5)">+</button>
         <button @click="exDis(5)">-</button>
      </p>
   </div>
</template>
<script>
import { mapActions,mapGetters,mapMutations,mapState } from 'vuex'
export default {
   name: 'comA',
   components: {
      
   },
   mixins: [],
   props: {
      
   },
   data() {
      return {
         
      }
   },
   computed: {
      ...mapState('comA', ['a', 'b']),
      ...mapGetters('comA',['sum'])
   },
   watch: {
      
   },
   mounted() {
      
   },
   methods: {
      toB() {
         this.$router.push('/comB?name=这是B界面')
      },
      ...mapMutations('comA', ['add']),
      ...mapActions('comA',['exDis'])
   }
};
</script>
<style lang='' scoped>
</style>
  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js是一个用于构建用户界面的渐进式JavaScript框架,而VuexVue.js官方提供的状态管理库,用于管理Vue.js应用中的数据流。下面是使用Vue 2和Vuex的步骤: 1. 安装Vuex:在项目目录下运行以下命令来安装Vuex: ``` npm install vuex ``` 2. 创建store:在项目中创建一个名为store.js(或者其他你喜欢的名字)的文件,并在其中导入VueVuex: ```javascript import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const store = new Vuex.Store({ // 在这里定义你的状态、mutations、actions等 }) export default store ``` 3. 定义状态:在store.js文件中,你可以定义应用的状态。状态是存储在Vuex中的数据,可以在整个应用中共享和访问。例如,你可以定义一个名为count的状态: ```javascript const store = new Vuex.Store({ state: { count: 0 } }) ``` 4. 定义mutations:mutations是用于修改状态的方法。你可以在mutations中定义一些方法来更新状态。例如,你可以定义一个名为increment的mutation来增加count的值: ```javascript const store = new Vuex.Store({ state: { count: 0 }, mutations: { increment(state) { state.count++ } } }) ``` 5. 使用状态和mutations:在Vue组件中,你可以通过`this.$store.state`来访问状态,通过`this.$store.commit`来调用mutations。例如,在一个组件中,你可以这样使用count状态和increment mutation: ```javascript export default { computed: { count() { return this.$store.state.count } }, methods: { increment() { this.$store.commit('increment') } } } ``` 以上是使用Vue 2和Vuex的基本步骤。当然,Vuex还提供了更多的功能,如actions、getters等,你可以根据具体需求进行学习和使用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值