說明
一直想做一個基于VUE的項目,但是因為項目往往要涉及到后端的知識(不會后端真的苦),所以就沒有一直真正的動手去做一個項目。
直到發現GitHub上有網易云音樂的api NeteaseCloudMusicApi ,才開始動手去做。
僅僅完成了首頁,登入,歌單,歌曲列表頁。
項目地址
https://github.com/qp97vi/music
項目成功運行還要把后端api在本地運行
前端技術棧
vue2+vuex+vue-router+axios+mint-ui+webpack
遇到的問題
1.前端路由攔截
想做一個登錄攔截,驗證沒有登錄之前,就跳轉到登錄頁面
解決方法是:通過http response 攔截器判斷token(本地的cookie)判斷
創建一個http.js
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
文章名稱:vue模仿網易云音樂的單頁面應用-創新互聯
瀏覽地址:http://www.2m8n56k.cn/article28/docicp.html
成都網站建設公司_創新互聯,為您提供商城網站、App設計、自適應網站、網站收錄、網站設計、關鍵詞優化
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯