前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >真正掌握vuex的使用方法(六)

真正掌握vuex的使用方法(六)

作者头像
用户1272076
发布2019-03-26 15:53:05
5070
发布2019-03-26 15:53:05
举报
文章被收录于专栏:张培跃张培跃

下面咱们来将切换的案例改为vuex来写! 首先需要在src目录下,新建一个store文件夹,然后在该文件夹内创建一个store.js文件

代码语言:javascript
复制
import Vue from 'vue';//引用vue
import Vuex from 'vuex';//引用vuex
Vue.use(Vuex);//使用vuex
const state={
    tagList:[],//用于存放与切换相关的数据
};
const mutations={
    //用于改变state下的tagList状态值
    SET_TAGLIST(state,v){//这里的state即是上面定义的state常量
        state.tagList=v;
    }
}
export default new Vuex.Store({//暴露Store对象
    state,
    mutations,//将mutations进行暴露
})

main.js为:

代码语言:javascript
复制
import Vue from 'vue'
import App from './App'
import router from './router'
import store from './vuex/store'//导入store.js
Vue.config.productionTip = false
new Vue({
    el: '#app',
    router,
    store,//添加store
    components: { App },
    template: '<App/>'
})

app.vue为:

代码语言:javascript
复制
<template>
<div id="app">
    <!--对按钮进行遍历-->
   <input type="button" v-for="(item,i) in tagList" :value="item.tagName" :class="{active:i==index}" @click="index=i">
    <!--对新闻进行遍历-->
    <div v-for="(item,i) in tagList" v-show="i==index">
        <p v-for="info in item.newList"><a :href="info.newHref">{{info.newTitle}}</a></p>
    </div>
</div>
</template>
<script>
    import axios from "axios";
    import {mapState} from "vuex";
    export default {
        name: 'App',
        data(){
            return {
                //index用于记录当前所选按钮的位置,值会根据点击按钮的不同而变化
                index:0
            }
        },
        computed:{
            ...mapState(["tagList"])
        },
        mounted(){
            axios.get("/static/tagList.json")
                .then(data=>{
                    this.$store.commit("SET_TAGLIST",data.data);
                })
        }
    }
</script>
<style>
    #app input,#app p{
        margin:5px;
        padding:5px;
    }
    #app input.active{
        background:red;
    }
    #app div{
        border:1px solid red;
    }
</style>

npm run dev,运行一次,一切正常! 到目前为止,相信大家看以上的代码应该都不会有太大问题了,所以不做解释! 咱们知道,对多个 state 的操作 , 使用 mutations 来操作比较好维护 , 但mutations 只可以写一些同步操作,那异步操作放到哪里呢?比如咱们的axios放在哪里比较合适呢?在这个时候咱们就可以用到action了。通过action来操作mutations最终来改变state的值。 接下来在store.js中添加actions:

代码语言:javascript
复制
import Vue from 'vue';//引用vue
import Vuex from 'vuex';//引用vuex
import axios from "axios"
Vue.use(Vuex);//使用vuex
const state={
    tagList:[]
};
const mutations={
    //用于改变state下的tagList状态值
    SET_TAGLIST(state,v){//这里的state即是上面定义的state常量
        state.tagList=v;
    }
}
const actions={
    getTagList:function(context){//这里的context和我们使用的$store拥有相同的对象和方法
        axios.get("/static/tagList.json")
            .then(data=>{
                context.commit("SET_TAGLIST",data.data);
                //根据需要,咱们还可以在此处触发其它的mutations方法
            })
    }
}
export default new Vuex.Store({//暴露Store对象
    state,
    mutations,//将mutations进行暴露
    actions//将actions进行暴露
})

那么接下来就要在App.vue中来触发action下的方法getTagList:

代码语言:javascript
复制
import {mapState} from "vuex";
export default {
    name: 'App',
    data(){
        return {
            //index用于记录当前所选按钮的位置,值会根据点击按钮的不同而变化
            index:0
        }
    },
    computed:{
        ...mapState(["tagList"])
    },
    mounted(){
        //使用 $store.dispatch('getTagList') 来触发 action 中的 getTagList 方法。
        this.$store.dispatch("getTagList");
    }
}

使用 $store.dispatch('getTagList') 来触发 action 中的 getTagList 方法。也推荐大家在action里来写一些异步方法! 当然调用action的方法也有简写的形式:

代码语言:javascript
复制
//引入mapActions
import {mapState,mapActions} from "vuex";
export default {
    name: 'App',
    data(){
        return {
            //index用于记录当前所选按钮的位置,值会根据点击按钮的不同而变化
            index:0
        }
    },
    methods:{
        //通过mapActions添加上action当中需要的方法getTagList
        ...mapActions(["getTagList"])
    },
    computed:{
        ...mapState(["tagList"])
    },
    mounted(){
        //直接调用 即可
        this.getTagList();
    }
}

npm run dev 运行,依旧完美! 未完,待续!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-05-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 张培跃 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档