1. <sup id="1kcns"></sup>

    2. <rt id="1kcns"><legend id="1kcns"></legend></rt>
      国产AV巨作丝袜秘书,国产精品久久香蕉免费播放,国产草草影院ccyycom,涩涩爱狼人亚洲一区在线,日本阿v片在线播放免费,国产精品一区二区三区蜜臀,精品一区二区三区在线观看l,av深夜免费在线观看

      vue.js路由與vuex數(shù)據(jù)模型設(shè)計(jì)

      2020-5-23    seo達(dá)人

      路由設(shè)計(jì)

      本則路由考慮驗(yàn)證進(jìn)入登錄頁(yè)面,完成登錄操作進(jìn)入首頁(yè)。


      import Vue from "vue";

      import Router from "vue-router";

      Vue.use(Router);


      import store from "@/store/store";


      // (延遲加載)

      const Login = () => import("@/views/login");

      const Home = () => import("@/views/home");


      const HomeRoute = {

       path: "/",

       name: "首頁(yè)",

       component: Home

      };


      export { HomeRoute };


      const router = new Router({

       base: process.env.BASE_URL,

       routes: [

         {

           path: "/login",

           name: "登錄",

           component: Login

         },

         HomeRoute

       ]

      });


      router.beforeEach((to, from, next) => {

       let loginName = store.state.user.loginName;

       if (to.path === "/" && loginName == "") {

         next("/login");

       } else {

         next();

       }

      });


      export default router;

      數(shù)據(jù)模型

      const state = {

       loginName: ""

      };

      const mutations = {

       SET_LOGINNAME(state, loginName) {

         state.loginName = loginName;

       }

      };

      const actions = {

       login({ commit }, userInfo) {

         return new Promise((res, ret) => {

           commit("SET_LOGINNAME", userInfo);

           res();

         });

       },

       logout({ commit }) {

         return new Promise((res, ret) => {

           commit("SET_LOGINNAME", "");

           res();

         });

       }

      };

      export default {

       namespaced: true,

       state,

       mutations,

       actions

      };

      import Vue from "vue";

      import Vuex from "vuex";

      Vue.use(Vuex);


      import user from "./modules/user";


      const store = new Vuex.Store({

       modules: {

         user

       }

      });


      export default store;

      組件

      <div class="modify">

       <input

         type="text"

         @keydown.enter.prevent="handleKeydown"

         v-model="currentVal"

         placeholder="使用enter鍵切換頻道"

       />

       <button @click="reset" style="margin-left:5px;outline:none;cursor:pointer;">復(fù)位</button>

      </div>

      import { mapState, mapMutations, mapActions } from "vuex";

      export default {

       name: "login",

       data() {

         return {

           currentVal: "",

           list: ["咨詢服務(wù)", "音悅臺(tái)", "體育臺(tái)", "財(cái)經(jīng)頻道", "時(shí)尚資訊"],

           index: 0

         };

       },

       computed: {

         ...mapState({

           loginName: state => state.user.loginName

         })

       },

       methods: {

         ...mapActions({

           login: "user/login"

         }),

         handleToHome() {

           let userInfo = "user";

           this.login(userInfo);

           this.$router.push({

             path: "/"

           });

         },

      日歷

      鏈接

      個(gè)人資料

      存檔

      主站蜘蛛池模板: 久久精品国产亚洲7777 | 蜜桃av在线| 韩国一区二区三区精品| 欧美.成人.综合在线| 日本一区二区三区视频一| 1024国产视频| 亚洲在线人妻| 国产亚洲成av人片在线观黄桃| 亚洲性日韩精品一区二区 | 亚洲国产AV一区二区三区四区| 国产精品爱久久久久久久| 好爽毛片一区二区三区四| 亚洲国产成人一区二区三区| 伊人精品无码AV一区二区三区| JIZZJIZZJIZZ亚洲日本| 韩国午夜福利片在线观看| 久久草视频在线| 亚洲少妇| 伊人成人免费在线视频| 久久精品人人做人人爽电影蜜月| 久久综合开心激情五月天| 亚洲av色一区二区三区| 国产亚洲蜜芽精品久久| 97久久人人超碰超碰窝窝| 好紧好湿好黄的视频| 日韩国产精品中文字幕| 国产精品无码午夜福利| 精品少妇人妻AV无码久久 | 国产无套丰满白嫩对白| 亚洲AV免费在线观看| 免费h片| 一区二区和激情视频| 秋霞电影院午夜无码免费视频| 精品国产一区二区三区四区无卡| 国产精品自拍中文字幕| 丰满少妇被猛烈进入毛片| 亚洲人成电影在线天堂色| xxxx免费| 无码中文字幕网| 欧美另类videossexotv人妖| 无码少妇视频|