vuex的简单使用

1.store->index.js

import Vuex from 'vuex'
import Vue from 'vue'


Vue.use(Vuex)

const store = new Vuex.Store({
  state:{
    curInx:0,
  },
  mutations:{
    //提供更改curInx的方法setCurInx
    //第一个参数就是state,第二个参数是要更改的数据
    setCurInx(state,index){
      console.log(index)
      state.curInx = index
    }
  }
})


export default store

2.tab->index.vue

<template>
    <div>
        <a href="javascript:;"
        :class="[{current: curInx == 0}]" @click="setCurInx(0)"
        >选项1</a>
        <a href="javascript:;"
        :class="[{current: curInx == 1}]" @click="setCurInx(1)"
        >选项2</a>
        <a href="javascript:;"
        :class="[{current: curInx == 2}]" @click="setCurInx(2)"
        >选项3</a>
        <a href="javascript:;"
        :class="[{current: curInx == 3}]" @click="setCurInx(3)"
        >选项4</a>
    </div>
   
</template>
  
<script>
  import {mapState,mapMutations} from 'vuex';
  export default {
    name: 'Tab',
    computed:{
        //mapState取出要用的值
        //mapMutations获取使用的方法
          ...mapState(['curInx'])
        //...mapState({
        //    curInx:(state)=> state.tab.curInx
        //})
    },
    methods:{
       ...mapMutations(['setCurInx'])
    }

  }
</script>
  
<style scoped>
  a{
    margin-right: 10px;
    color: aqua;
  }
  .current{
    color: #000;
    text-decoration: none;
  }
</style>
  

page->index.vue

<template>
 <div>{{content[curInx]}}</div>
</template>
<script>
import {mapState} from 'vuex';
 export default{
    name: 'Page',
    computed:{
          ...mapState(['curInx'])
        //...mapState({
        //    curInx:(state)=> state.tab.curInx
        //})
    },
    data(){
        return{
            content:[
                '页面1',
                '页面2',
                '页面3',
                '页面4',
            ]
        }
    }
 }
</script>
<style scoped>
</style>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值