記一次vue仿網易雲音樂的單頁面應用

說明

一直想作一個基於VUE的項目,可是由於項目每每要涉及到後端的知識(不會後端真的苦),因此就沒有一直真正的動手去作一個項目。
直到發現GitHub上有網易雲音樂的api NeteaseCloudMusicApi,纔開始動手去作。前端

僅僅完成了首頁,登入,歌單,歌曲列表頁。vue

項目地址

https://github.com/qp97vi/music
項目成功運行還要把後端api在本地運行webpack

前端技術棧

vue2+vuex+vue-router+axios+mint-ui+webpackios

前端路由攔截解決方案 原文 感謝!!!

遇到的問題

1.前端路由攔截
想作一個登陸攔截,驗證沒有登陸以前,就跳轉到登陸頁面
解決方法是:經過http response 攔截器判斷token(本地的cookie)判斷
建立一個http.jsgit

import axios from 'axios'
import store from './store/store'
import * as types from './store/types'
import router from './router/index'

// axios 配置
axios.defaults.timeout = 5000
axios.defaults.baseURL = 'https://api.github.com'

// http request 攔截器
axios.interceptors.request.use(
  config => {
    if (store.state.xsrfCookieName) {
      config.headers.Authorization = `xsrfCookieName ${store.state.xsrfCookieName}`
    }
    return config
  },
  err => {
    return Promise.reject(err)
  },
)

// http response 攔截器
axios.interceptors.response.use(
  response => {
    return response
  },
  error => {
    if (error.response) {
      switch (error.response.status) {
        case 401:
          // 401 清除token信息並跳轉到登陸頁面
          store.commit(types.LOGOUT)
          
          // 只有在當前路由不是登陸頁面才跳轉
          router.currentRoute.path !== 'login' &&
            router.replace({
              path: 'login',
              query: { redirect: router.currentRoute.path },
            })
      }
    }
    // console.log(JSON.stringify(error));//console : Error: Request failed with status code 402
    return Promise.reject(error.response.data)
  },
)

export default axios

2.路由懶加載github

{
      path:'/my',
      name:'my',
       meta:{
        requireAuth:true,
      },
      component:resolve=>{
        Indicator.open('加載中...');
        require.ensure(['@/views/my'], () => {
          resolve(require('@/views/my'))
          Indicator.close()
        })
      }
    },

注:本文僅是用來記錄學習,如涉及侵權請聯繫刪除。web

相關文章
相關標籤/搜索