Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hua1995116/musiccloudwebapp
:headphones:vuejs仿网易云音乐
https://github.com/hua1995116/musiccloudwebapp
audio music vue
Last synced: 3 days ago
JSON representation
:headphones:vuejs仿网易云音乐
- Host: GitHub
- URL: https://github.com/hua1995116/musiccloudwebapp
- Owner: hua1995116
- Created: 2017-03-23T04:30:37.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-06-21T10:27:13.000Z (7 months ago)
- Last Synced: 2024-12-27T11:09:00.830Z (10 days ago)
- Topics: audio, music, vue
- Language: Vue
- Homepage: http://www.huayifeng.top:8080
- Size: 8.05 MB
- Stars: 727
- Watchers: 37
- Forks: 265
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# 用vuejs仿网易云音乐(实现听歌以及搜索功能)
前端时间学了vue,一开始看了vue1.0,后来实在觉得技术总得实践,就直接上手vue2.0。然后花了将近一周时间做了一个网易云音乐的小项目。一开始觉得项目比较小,没必要用vuex所以就没有使用,但是后来发现数据流传输有点麻烦,后续会使用vuex。## 传送门
推荐一个项目[vue+websocket+express+mongodb实战项目(实时聊天)](https://github.com/hua1995116/webchat)
## 技术栈
- vue+vue-router(核心框架)
- [better-scroll](https://github.com/ustbhuangyi/better-scroll)(使移动端滑动体验更加流畅)
- [vue-lazyload](https://www.npmjs.com/package/vue-lazyload)(用户图片懒加载)
- [nprogress](https://www.npmjs.com/package/nprogress)(用于加载过渡)
- [ axios](https://www.npmjs.com/package/axios)(请求)## 功能分析与设计
首先我先参考了现有的一些APP的设计与开发,然后决定做了歌单和搜索两个模块,本身主要以前端为主,后端代码并没有研究,这里要感谢这位同学写的[API](https://github.com/zvenshy/venmusic)。如果你没有API也没有关系,这并不影响我们的开发,你可以写如下形式的json数据进行模拟:![这里写图片描述](http://img.blog.csdn.net/20170329172932380)
**vuejs**
路由结构如下
![这里写图片描述](http://img.blog.csdn.net/20170329173152290)
以下是组件
![这里写图片描述](http://img.blog.csdn.net/20170329173309870)
1.歌单部分:
数据主要由API提供,源码中有具体地址。需要了解audio标签,不熟悉的同学看[audio](http://www.cnblogs.com/tianma3798/p/6033108.html)2.搜索部分:
通过绑定@keydown来绑定事件,实现实时查询。**better-scroll**
使用:
1.一定要用一个空层来承载```
//你的代码
```2.在vue中使用前必须引入
```
import BScroll from 'better-scroll';this.helloScroll = new BScroll(this.$refs.helloWrapper, {
click: true
});
```
一定要在数据渲染完成后使用better-scroll,```
this.$nextTick(() => {
//调用
});
```最后上几张效果图
![这里写图片描述](http://img.blog.csdn.net/20170329175225335?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmx1ZWJsdWVza3lodWE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
![这里写图片描述](http://img.blog.csdn.net/20170329175246881?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmx1ZWJsdWVza3lodWE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
![这里写图片描述](http://img.blog.csdn.net/20170329175301320?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmx1ZWJsdWVza3lodWE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
github项目地址:[https://github.com/hua1995116/musiccloudWebapp/](https://github.com/hua1995116/musiccloudWebapp/)
在线演示地址:[http://www.qiufengh.com/#/](http://www.qiufengh.com/#/)
需要改进的有很多,请大家可以多提提意见。后续我会不断改进,如果觉得还可以,请star,你们的star是我前进的动力。