zoukankan      html  css  js  c++  java
  • vuex使用

    什么是 Vuex

    Vuex 是一个专为 Vue.js 应用开发的 状态管理模式 , 它可以集中管理应用所有组件的状态。我们经常会遇到多个组件共享状态的情况,以我们前面注册的用户信息为例,登录注册入口要使用这个用户信息,来判断是否显示用户名,这就需要我们在注册成功时,以某种方式通知登录注册入口,用户信息已经改变,使用 Vuex 不但可以轻松的实现通知,还可以在状态改变后响应式的反应到我们的界面上。

    安装 Vuex

    > npm install vuex --save

    创建 store

    在 src 新建 store 文件夹,然后新建 index.js 文件,复制贴入以下代码:

    src/store/index.js

    import Vue from 'vue'
    import Vuex from 'vuex'
    import ls from '../utils/localStorage'
    import router from '../router'
    
    Vue.use(Vuex)
    
    const state = {//// 用户信息,初始值从本地 localStorage 获取
      user: ls.getItem('user')
    }
    
    const mutations = {
      UPDATE_USER(state, user) {
        state.user = user// 改变 user 的值
        ls.setItem('user', user)// 将改变后的值存入 localStorage
    //上面的 UPDATE_USER 是事件类型名称,大写不是必须的,后期可以使用常量代替事件类型。参数 state 是当前仓库的 stateuser 是用户传入的参数,多参数的时候应该使用一个对象。
    } } const actions
    = { login({ commit }, user) {//// 登录时有传用户信息,就更新下用户信息 if (user) commit('UPDATE_USER', user) router.push('/')//// 跳转到首页 } } const store = new Vuex.Store({ state, mutations, actions }) export default store

    我们使用 new Vuex.Store 创建了一个新的 store(仓库)实例,其配置项说明:

    • state:共享的状态,我们不能直接更改状态,但是可以像 store.state.user 这样访问一个状态;
    • mutations:更改状态的方法,我们可以在这里更改状态,调用方法是像 store.commit('UPDATE_USER', user) 这样提交一个事件类型,这里不能包含异步操作;
    • actions:类似于 mutations,但我们不在这里直接更改状态,而是提交前面的 mutation,调用方法是像 store.dispatch('login') 这样分发一个事件,这里可以包含异步操作;
     1 <!-- 字符串 -->
     2 <router-link to="/">Home</router-link>
     3 
     4 <!-- 含路径的对象 -->
     5 <router-link :to="{ path: '/' }">Home</router-link>
     6 
     7 <!-- 含命名的对象 -->
     8 <router-link :to="{ name: 'Home' }">Home</router-link>
     9 
    10 <!-- 含参数和查询参数的对象 -->
    11 <router-link :to="{ params: { id: 1 }, query: { page: 1 } }">Home</router-link>

    引入 store

    打开 src/main.js 文件,引入并注入 store(单行注释部分是涉及的修改):

    src/main.js

    import Vue from 'vue'
    import App from './App'
    import router from './router'
    import './directives'
    import './components'
    // 引入 store/index.js 的默认值
    import store from './store'
    
    Vue.config.productionTip = false
    
    /* eslint-disable no-new */
    new Vue({
      el: '#app',
      router,
      // 注入 store
      store,
      components: { App },
      template: '<App/>'
    })

    我们通过 store 选项,将仓库实例注入到每一个子组件中,这样子组件就能通过 this.$store 访问仓库。

    修改注册逻辑

    打开 src/views/auth/Register.vue 文件,修改注册的逻辑:

    src/views/auth/Register.vue

    1 // 修改
    2 const localUser = ls.getItem('user')
    3 // 为 => 从仓库获取用户信息
    4 const localUser = this.$store.state.user
    5 
    6 // 修改
    7 ls.setItem('user', user)
    8 // 为 => 分发 login 事件,以保存用户信息和登录
    9 this.$store.dispatch('login', user)
  • 相关阅读:
    HDU5029--Relief grain (树链剖分+线段树 )
    codeforces 277.5 div2 F:组合计数类dp
    FZU2176---easy problem (树链剖分)
    Codeforces Round #277.5 (Div. 2) --E. Hiking (01分数规划)
    FZU 11月月赛D题:双向搜索+二分
    POJ
    POJ
    HDU 4746 Mophues(莫比乌斯反演)
    BZOJ 2005 能量采集 (莫比乌斯反演)
    BZOJ 2301 Problem b (莫比乌斯反演+容斥)
  • 原文地址:https://www.cnblogs.com/yangguoe/p/9309739.html
Copyright © 2011-2022 走看看