摘要:簡(jiǎn)介最近有點(diǎn)小閑置,于是乎希望寫(xiě)點(diǎn)東西,正好自己喜歡聽(tīng)歌,便決定自己寫(xiě)一個(gè)音樂(lè)的簡(jiǎn)易版。核心文件則是在在這里使用統(tǒng)一管理頁(yè)面切換動(dòng)畫(huà),歌曲播放狀態(tài),歌曲進(jìn)度等信息。所有對(duì)于歌曲的操作都通過(guò)來(lái)進(jìn)行全局管理,然后對(duì)相應(yīng)的變化做出全局改變。
Vue-QQMusic 簡(jiǎn)介:
最近有點(diǎn)小閑置,于是乎希望寫(xiě)點(diǎn)東西,正好自己喜歡聽(tīng)歌,便決定自己寫(xiě)一個(gè)QQ音樂(lè)的簡(jiǎn)易版。
順便進(jìn)一步加深下自己對(duì)移動(dòng)端的知識(shí)。我會(huì)在每個(gè)核心組件和部分都加下注解大致說(shuō)明原理,爭(zhēng)取提供一個(gè)良好的代碼閱讀環(huán)境,在注視部分是采用英文寫(xiě)的,請(qǐng)?jiān)徫移材_的英語(yǔ)o(╯□╰)o,歡迎大家給我提出更好的意見(jiàn)( *︾▽?duì)?
首先這里通過(guò)Jsonp來(lái)進(jìn)行跨域獲取QQ音樂(lè)API數(shù)據(jù),在API Hanler對(duì)API進(jìn)行處理導(dǎo)出統(tǒng)一的方法來(lái)獲取數(shù)據(jù)。
核心文件則是在Store,在這里使用Vuex統(tǒng)一管理頁(yè)面切換動(dòng)畫(huà),歌曲播放狀態(tài),歌曲進(jìn)度等信息。所有對(duì)于歌曲的操作都通過(guò)Vuex來(lái)進(jìn)行全局管理,然后對(duì)相應(yīng)的變化做出全局改變。
Vue全家桶(使用Vue-cli作為構(gòu)建工具)
Webpack
Mint-Ui
Es6
Sass
Velocity, AlloyTouch等第三方庫(kù)
運(yùn)行演示 線(xiàn)上地址:Vue-QQMusic 源碼地址:源碼 移動(dòng)端請(qǐng)掃描下面二維碼: 運(yùn)行截圖:[x] 首頁(yè) -- 完成
[ ] 電臺(tái) -- 無(wú)法獲取電臺(tái)API
[X] 歌手信息 -- 完成
[X] 歌手列表 -- 完成
[x] 歌曲排行 -- 完成
[x] 歌曲列表 -- 完成
[x] 熱門(mén)推薦 -- 完成
[x] 歌曲搜索 -- 完成
[x] 歌曲播放 -- 完成
[x] 底部固定歌曲播放條 -- 完成
項(xiàng)目結(jié)構(gòu)|-- build // webpack配置文件 |-- config // 項(xiàng)目打包路徑 |-- src ? ? ? ? ? ? ? ? ? ? ? ? ? ? // 源碼目錄 | ? |-- api ? ? ? ? ? ? ? ? ? ? ? ? // QQ音樂(lè)Api分析文件 | |-- index.js ? ? ? ? ? ? ? ? | |-- assets ? ? ? ? ? ? ? ? ? ? ? // 圖片資源文件 | ? |-- components ? ? ? ? ? ? ? ? ? // 組件 | ? ? ? |-- fallback.vue ? ? ? ? ? ? // 公用后退組件 | ? ? ? |-- header.vue ? ? ? ? ? // 重寫(xiě)Mini-Ui頭部組件,來(lái)實(shí)現(xiàn)更多效果 | ? ? ? |-- index.vue ? ? ? ? ? ? ? // 首頁(yè)界面 | ? ? ? |-- list.vue ? ? ? ? ? ? ? ? // 公用歌曲列表組件 | ? ? ? |-- lyrics.vue ? ? ? ? ? ? ? // 歌詞組件 | ? ? ? |-- play-fixed.vue ? ? ? ? ? // 底部固定歌曲播放組件 | ? ? ? |-- playing.vue ? ? ? ? ? ? // 歌曲播放頁(yè)面 | ? ? ? |-- radio.vue ? ? ? ? ? ? ? // 電臺(tái)界面 | ? ? ? |-- ranklist.vue ? ? ? ? ? ? // 歌曲排行榜界面 | ? ? ? |-- recommend.vue ? ? ? ? ? ?// 推薦歌曲界面 | ? ? ? |-- search.vue ? ? ? ? ? ? ? // 搜索界面 | ? ? ? |-- singer.vue ? ? ? ? ? ? ? // 歌手界面 | ? ? ? |-- singerlist.vue ? ? ? ? ? // 歌手列表界面 | ? ? ? |-- slider.vue ? ? ? ? ? ? ? // 歌詞滑動(dòng)組件 | ? ? ? |-- special.vue ? ? ? ? ? ? // 特殊界面用于使用Iframe包含封面等QQ音樂(lè)原生界面 | ? ? ? |-- toplist.vue ? ? ? ? ? ? // QQ音樂(lè)巔峰榜界面 | ? |-- mixin ? ? ? ? ? ? ? ? ? ? ? // 全局mixin方法 | ? ? ? |-- index.js ? ? ? ? ? | ? |-- router ? ? ? ? ? ? ? ? ? ? ? // Vue 路由 | ? ? ? |-- index.js | ? |-- sass ? ? ? ? ? ? ? ? ? ? ? ? // css文件夾,采用Sass進(jìn)行預(yù)編譯 | ? ? ? |-- packages ? ? ? ? ? ? ? ? // Mint-Ui文件夾,覆蓋Mint-Ui原有樣式 | ? ? ? ? ? ?|-- cell.scss | ? ? ? ? ? ?|-- header.scss | ? ? ? ? ? ?|-- index.scss | ? ? ? ? ? ?|-- navbar.scss | ? ? ? ? ? ?|-- search.scss | ? ? ? |-- themes ? ? ? ? ? ? ? ? ? // APP主題CSS,未來(lái)將增加主題切換功能 | ? ? ? ? ? |-- index.scss | ? ? ? |-- transition ? ? ? ? ? ? ? // 全局公用Transition, Animation | ? ? ? ? ? ?|-- index.scss | ? ? ? |-- dimension.scss ? ? ? ? ? // 阿里SUI, Rem屏幕適應(yīng)變化css(暫未使用) | ? ? ? |-- index.scss ? ? ? ? ? ? ? // Sass 入口文件 | ? ? ? |-- mixins.scss ? ? ? ? ? ? // Sass 公用全局Mixin | ? ? ? |-- normalize.scss ? ? ? ? ? // Normalize.css | ? ? ? |-- page.scss ? ? ? ? ? ? ? // 頁(yè)面布局css | ? ? ? |-- scaffold.scss ? ? ? ? ? // scaffold css 設(shè)置基本全局樣式 | ? ? ? |-- util.scss ? ? ? ? ? // 公用全局Sass組件 | ? ? ? |-- var.scss ? ? ? ? ? // 全局Sass變量,這里使用sass-resources-loader向全局注入Sass變量 | ? |-- store ? ? ? ? ? ? ? ? ? ? ? // Vuex Store文件,APP核心所在 | ? ? ? |-- index.js ? ? ? | ? |-- util ? ? ? ? ? ? ? ? ? ? ? ? // 全局公用函數(shù) | ? ? ? |-- index.js ? ? ? ? ? ? ? ? | ? |-- App.vue ? ? ? ? ? ? ? ? ? ? // App入口文件 | ? |-- filter.js? ? ? ? ? ? ? ? ? ? // 注冊(cè)全局Vue filter | ? |-- main.js ? ? ? ? ? ? ? ? ? ? // 程序入口文件,加載Vuex,Vue-router等插件 | ? |-- mintUi.js ? ? ? ? ? ? ? ? ? // Mint-Ui配置文件 | ? |-- test ? ? ? ? ? ? ? ? ? ? ? ? // 測(cè)試目錄,暫未使用 |-- .babelrc ? ? ? ? ? ? ? ? ? ? ? ? // ES6語(yǔ)法編譯配置 |-- .editorconfig // 代碼編寫(xiě)規(guī)格 |-- .eslintignore ? ? ? ? ? ? ? ? ? // Eslint 忽略的文件 |-- .eslintrc.js ? ? ? ? ? ? ? ? ? ? // EsLint 配置?暫未使用 |-- .gitignore // git ingnore |-- .postcssrc.js ? ? ? ? ? ? ? ? ? // post css 配置文件 |-- README.md // README |-- index.html ? ? ? ? ? ? ? ? ? ? ? // 入口html文件 `-- package.json // 項(xiàng)目及工具的依賴(lài)配置文件Build Setup
# download git clone https://github.com/Panda-Hope/vue-qqmusic # install dependencies npm install # serve with hot reload at localhost:8080 npm run dev # build for production with minification npm run build # build for production and view the bundle analyzer report npm run build --report # run unit tests npm run unit # run e2e tests npm run e2e # run all tests npm test
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/83204.html
摘要:原創(chuàng),基本上是界面,新加了七八個(gè)功能,解決了前輩閱讀器上的絕大部分,并成功添加路徑打包成。畢竟只是一個(gè)學(xué)習(xí)項(xiàng)目跨域問(wèn)題本次開(kāi)發(fā)使用的是代理追書(shū)神器,是不需要后臺(tái)認(rèn)證直接可以跨域的接口,以實(shí)現(xiàn)在移動(dòng)端顯示的效果。 應(yīng)屆畢業(yè)生,目前正在找工作,簡(jiǎn)歷需要所以開(kāi)發(fā)了這個(gè)app。剛開(kāi)始開(kāi)發(fā)也是一臉懵逼,因?yàn)闆](méi)得后臺(tái),一些邏輯功能也不知道怎么拓展。好在看到了追書(shū)神器api接口,頓時(shí)讓我決心做出這一...
摘要:庫(kù)用了魔改樣式的歌詞滾動(dòng)部分用了黃軼老大的賊爽主題換膚用的變量替換。語(yǔ)言的下一代標(biāo)準(zhǔn)預(yù)處理器安裝與使用前端項(xiàng)目后端項(xiàng)目 音樂(lè)播放器雖然爛大街了,但是作為前端沒(méi)自己擼一個(gè)一直是個(gè)遺憾,而且偶然間發(fā)現(xiàn)pc端web版的網(wǎng)易云音樂(lè)做的實(shí)在是太簡(jiǎn)陋了,社區(qū)仿pc客戶(hù)端的網(wǎng)易云也不多見(jiàn),為了彌補(bǔ)這個(gè)遺憾,就用vue全家桶模仿mac客戶(hù)端的ui實(shí)現(xiàn)了一個(gè),歡迎提出意見(jiàn)和star~ 預(yù)覽地址 源碼地址...
摘要:一個(gè)基于全家桶開(kāi)發(fā)的仿知乎日?qǐng)?bào)單頁(yè)應(yīng)用項(xiàng)目地址源碼地址項(xiàng)目在線(xiàn)地址在線(xiàn)地址模式下推薦使用移動(dòng)端模式瀏覽去觀看如果覺(jué)得做得還不錯(cuò)或者項(xiàng)目源碼對(duì)您有幫助希望您小抬右手到右上角點(diǎn)一個(gè)您的支持是作者長(zhǎng)期更新維護(hù)的動(dòng)力項(xiàng)目起源從二月份開(kāi)始學(xué)習(xí)學(xué)習(xí)了 Vue-News 一個(gè)基于vue全家桶開(kāi)發(fā)的仿知乎日?qǐng)?bào)單頁(yè)應(yīng)用 項(xiàng)目github地址:源碼地址 項(xiàng)目在線(xiàn)地址:在線(xiàn)地址 (PC模式下推薦使用chro...
摘要:全家桶還有就是組件庫(kù)開(kāi)頭在線(xiàn)預(yù)覽舊的版本移動(dòng)端商城新的版本移動(dòng)端商城項(xiàng)目演示地址移動(dòng)端商城建議調(diào)試手機(jī)模式下預(yù)覽因?yàn)閯傎I(mǎi)的域名主機(jī)所以要解析,實(shí)名認(rèn)證才可以瀏覽,所以你們還是下把項(xiàng)目給下載下來(lái)本地運(yùn)行看把 vue全家桶 vue2.0+vuex+axios+better-scroll還有就是miut-ui組件庫(kù) 開(kāi)頭 在線(xiàn)預(yù)覽 舊的版本:vivo移動(dòng)端商城新的版本:vivo移動(dòng)端商城項(xiàng)目...
好久沒(méi)更新過(guò)Vue的小文章,上次做了一個(gè)基于Vue+Mint-ui的移動(dòng)端AppDemo,集成了推送功能,然后通過(guò)cordova打包生成apk,移動(dòng)端表現(xiàn)還不錯(cuò),今天把這個(gè)小東西分享出來(lái),希望有更多的小伙伴能夠用Vue去做一些有意思的東西,本人才疏學(xué)淺,有說(shuō)的不對(duì)的地方,還請(qǐng)大家多多指教。下面按照慣例放上demo地址和源碼地址,希望大家能給我點(diǎn)下star:Demo(進(jìn)去需要先注冊(cè)才能登錄,用的lo...
閱讀 2310·2021-11-25 09:43
閱讀 2945·2019-08-30 15:52
閱讀 1897·2019-08-30 15:44
閱讀 985·2019-08-30 10:58
閱讀 764·2019-08-29 18:43
閱讀 3220·2019-08-29 18:36
閱讀 2321·2019-08-29 17:02
閱讀 1461·2019-08-29 17:01