<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                [TOC] ### 1. 項目結構 ![](https://img.kancloud.cn/d3/dd/d3dd8865a2752ca372670045ff6a61ab_280x184.png) ### 2. app-config.js , user.js (token) ~~~ const appConfig = { // 命名空間 namespaced: true, state: { data: '' }, mutations: { SET_APP_CONFIG(state, data) { state.data = data } } } export default appConfig ~~~ ~~~ // user.js import { login, logout } from '@/api/login' import { setToken } from '@/utils/token' const user = { // 命名空間 namespaced: true, state: { token: '' }, mutations: { SET_TOKEN(state, token) { state.token = token } }, actions: { Login({ commit }, userInfo) { const loginName = userInfo.loginName.trim() const { password } = userInfo return new Promise((resolve, reject) => { login({ loginName, password }) .then(res => { console.log(res) const { token } = res setToken(token) commit('SET_TOKEN', token) resolve('success') }) .catch(err => { reject(err) }) }) }, Logout({ commit }) { return new Promise((resolve, reject) => { logout() .then(res => { console.log(res) const { token } = res setToken(token) commit('SET_TOKEN', token) resolve('success') }) .catch(err => { reject(err) }) }) } } } export default user ~~~ ~~~ // src/utils/token // cookie保存token (要裝js-cookie插件) import Cookies from 'js-cookie' const TokenKey = 'DME-Token' export function getToken() { return Cookies.get(TokenKey) } export function setToken(token) { // 過期時間為1天 return Cookies.set(TokenKey, token, { expires: 1 }) } export function removeToken() { return Cookies.remove(TokenKey) } ~~~ ### 3. getters.js(注意后面state后面跟的是module中的導出名里data的數據) ~~~ const getters = { token: state => state.user.token, dataSource: state => state.dataSource.data, dataModel: state => state.dataModel.data, appConfig: state => state.appConfig.data } export default getters ~~~ ### 4. index.js ~~~ import Vue from 'vue' import Vuex from 'vuex' import user from './modules/user' import dataSource from './modules/data-source' import dataModel from './modules/data-model' import appConfig from './modules/app-config' import getters from './getters' Vue.use(Vuex) export default new Vuex.Store({ modules: { user, dataSource, dataModel, appConfig }, getters }) ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看