本則路由考慮驗證進入登陸頁面,完成登陸操做進入首頁。vue
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: "首頁", 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;
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;">復位</button> </div>
import { mapState, mapMutations, mapActions } from "vuex"; export default { name: "login", data() { return { currentVal: "", list: ["諮詢服務", "音悅臺", "體育臺", "財經頻道", "時尚資訊"], 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: "/" }); }, handleKeydown() { this.currentVal = this.list[this.index]; this.index++; let len = this.list.length - 1; if (this.index > len) { this.index = 0; } }, reset() { this.index = 0; this.currentVal = ""; } } };