赞
踩
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { isLogin:localStorage.getItem("isLogin")?localStorage.getItem("isLogin"):false,//判断是否登录 }, mutations: { //判断是否登录 setLogin(state,payload){ state.isLogin=payload localStorage.setItem("isLogin",state.isLogin) }, //退出登录 logout(state){ console.log("[退出登录]",state) state.isLogin=false localStorage.clear();//清除本地缓存 } }, actions: { getLogin(context,payload){ context.commit("setLogin",payload) } }, modules: { } })
<script> import { mapState, mapActions,mapMutations } from "vuex" export default { name:"index", data() { return { } }, computed:{ ...mapState({ isLogin:state=>state.isLogin }),//等同于==>...mapState(['isLogin']);映射 this.isLogin 为 this.$store.state.isLogin }, mounted(){ console.log("[mapState]",this.isLogin) this.$store.state.isLogin;//等同于==》this.isLogin this.$store.dispatch("getLogin",true);//等同于==》this.getLogin(true);dispatch触发actions里的方法,Action 提交的是 mutation,而不是直接变更状态,Action 可以包含任意异步操作 this.$store.commit("logout");//等同于==》this.logout();commit触发mutations里的方法,更改 Vuex 的 store 中的状态的唯一方法是提交 mutation console.log(this.$store.state.isLogin) console.log(localStorage.getItem("isLogin")) }, methods:{ ...mapMutations(["logout"]),// 将 `this.logout()` 映射为 `this.$store.commit('logout')` ...mapActions(["getLogin"]),// 将 `this.getLogin()` 映射为 `this.$store.dispatch('getLogin')` } } </script>
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。