用Vue高仿qq音乐官网-pc端

用Vue高仿qq音乐官网-pc端

大家好,又见面了,我是全栈君。

一直想做一个vue项目 然后呢 我就做了

效果预览

部分地方不全部根据原版,也有自由发挥的,目前功能模块比较简陋,如果加载太慢,可以下载下来再本地运行

 网易云音乐API

项目地址:github

预览地址:demo

Build Setup

# install dependencies
cnpm i
(可以用cnpm或yarn,更方便快捷,你值得拥有)

# serve with hot reload at localhost:8564
npm run dev

# build for production with minification
npm run build

# build for production and view the bundle analyzer report
npm run build --report

# 网易云API部署 listen localhost:3000
npm run start 

技术栈

  • vue(数据绑定)

  • vue-router

  • vuex(管理组件状态,实现组件通信)

  • webpack(打包工具)

  • scss(原来想用stylus,回头看看我都快写完了…)

  • axios(我等下要重点讲这**)

  • 组件库: element-UI(本来想用muse-UI,感觉那个更cool,下次吧..)

  • API: 网易云音乐API(仿qq音乐我用网易云音乐的东西,你怕不怕…)

核心功能组件的实现

搜索功能

用Vue高仿qq音乐官网-pc端

播放功能

用Vue高仿qq音乐官网-pc端
   (播放页面正在完善中,样式只是大概,待细化…)

跳转功能

用Vue高仿qq音乐官网-pc端

(目前子目录只开通歌手列表)

自己挖的坑,自己埋

vuex的模块应用

  •  一开始我并没有使用vuex,因为我觉得目前这个项目比较小,并不需要它来管理数据,毕竟vuex针对大项目来说确实很好用,但是后来考虑到如果后期该项目我还要 维护,数据量一大,还是要重新分类数据,所以中途某些地方插入了vuex的使用,这就很大一部分影响了项目进行的进度。(目前只用到action和state)

qq音乐的轮播图

  • 不用说,qq音乐这个网站的页面我是真的挺喜欢,不光是他的设计,页面的布局也很美观,在控制台调试的时候可以看看它的结构,非常有层次而富有美感,即使加上 一层margin,padding也不会有违和感。这就造就了它的轮播图结构比较麻烦,不是说做不出来,因为这是第一次上传的项目,我想先将大概的结构完善一下,后期再 维护,所以我就选用了element-UI里面的跑马灯式轮播图组件,大体来说,除了部分瑕疵以外,还是高度还原了原版轮播图的。

axios后端数据获取时产生的跨域问题

  •  重点来了,这个是我在该项目中花了最多时间的地方,相信很多同学使用axios都碰到过我这个问题,目前我这里使用了三种方法处理该问题,请大家针对自己的项目问题对号入座
       

  • 跨域访问,简单来说就是 A 网站的 javascript 代码试图访问 B 网站,包括提交内容和获取内容。由于安全原因,跨域访问是被各大浏览器所默认禁止的。
       

①. 针对本地相同端口服务器之间的跨域

  • 这是我刚开始碰到问题时使用的第一种,这个时候你只需要找到build文件中的dev-server,找到引用express的位置,给它加上一个头文件:

    app.all('*', function (req, res, next) {
    res.header("Access-Control-Allow-Credentials", true)
    res.header("Access-Control-Allow-Origin", "*")
    res.header("Access-Control-Allow-Headers", "X-Requested-With")
    res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS")
    res.header("X-Powered-By", ' 3.2.1')
    res.header("Content-Type", "application/json;charset=utf-8")
    next()
    })

用Vue高仿qq音乐官网-pc端

  • 然后它就会报错~,具体原因是你同一个端口申请相同端口的东西,不好意思,那不叫跨域…

②. 针对本地不同端口的服务器之间的跨域

  • 就是将上面的头文件放在当前项目申请的服务器的那个api中。

③. 针对本地服务器对域名服务器访问的跨域问题

  • 找到当前项目congfig文件夹下index.js文件,然后在文件中将proxyTable内容改为:

    proxyTable: {
       '/api': {
       target: '[1]',
       changeOrigin: true,
       pathRewrite: {
       '^/api': '/'
       }
      }
     }

就是你当前想访问的api地址,项目中访问的时候就只要用/api做反向代理即可

终于

  •  这是我第一个用vue撸的项目,可能功能有点简陋,很多地方有待提高,不过这次实践让我对组件化的理解有了一定的提升,后期会继续加入其它功能模块的,文中有用词不对的地方,欢迎大家指出,项目有什么bug,也希望大家多多提issue

  • 如果对你有帮助,给个star吧

  • 找工作中

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108413.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SNMP协议是什么「建议收藏」

    SNMP协议是什么「建议收藏」SNMP协议概念SNMP:简单网络管理协议(SimpleNetworkManagementProtocol)是由互联网工程任务组定义的一套网络管理协议。该协议是基于简单网络监视协议(SimpleGatewayMonitorProtocol,SGMP)制定的。SNMP可以使网络管理员通过一台工作站完成对计算机、路由器和其他网络设备的远程管理和监视。利用SNMP协议可以更好地管理和监控网络。管理工作站可以远程管理所有支持该协议的网络设备,如监视网络状态、修改网络设备配置、接收网络事件警

    2022年10月16日
    2
  • AC 自动机_模式匹配自动机

    AC 自动机_模式匹配自动机学习AC自动机的前提是要会trie数和KMP字符串匹配,它的功能是能对好多个模式串进行同时查找。比如对4个模式串:hehershisshe在一条母串中:shejjjjj查找每个模式串出现的次数.我们知道KMP算法有个next数组,和KMP类似,AC自动机有一个fail指针数组,用来对整棵trie树进行滚动。AC 自动机:HUD 3065:#i

    2025年6月30日
    4
  • 海思hi3518ev300说明书_海思3516dv300方案开发

    海思hi3518ev300说明书_海思3516dv300方案开发1.硬件内置AudioCodec/外置FM1288,hi3516dv300为内置audiocodec,硬件上外接FM1288,通过MIC单端/差分输入音频.2.重要概念2.1.I2S相关概念(1)LRCLK(帧时钟,也称为WS) 当LRCLK为低电平时表示左声道,高电平时表示右声道, LRCLK的频率=采样频率(2)SCLK(串行时钟),也叫BCLK(位时钟);方波形式存在 对应数字音频的每一位数据,SCLK都有一个脉冲. SCLK的频率=2*采样频率*采样位数

    2022年9月23日
    2
  • linux如何查看so库已加载_cmake生成静态库

    linux如何查看so库已加载_cmake生成静态库Linux程序运行找不到动态库.so文件的三种解决办法方法一:添加环境变量方法1.添加当前用户当前终端的环境变量-临时exportLD_LIBRARY_PATH=/home/czd/…#.sofilepath方法2.添加当前用户的环境变量修改~/.bashrc文件,在其末尾,添加环境变量vim~/.bashrcexportLD_LIBRARY_PATH=$LD…

    2022年9月18日
    1
  • potPlayer 快捷键[通俗易懂]

    potPlayer 快捷键[通俗易懂]空格:播放/暂停 Enter/Alt+Enter:全屏  c–加速  x–减速  z–恢复原速度,再次则恢复上次速度(类似以前电视机的【回看】功能) Tab:显示当前播放视频信息 H:书签管理器 P:添加书签 M:静音 第一行除【p】外:调整图像色彩、亮度、对比度、饱和度、复位 D:定位上一帧,省去截屏与倒退的烦恼 F:定位下一帧 G:直接输入定位位置 0:…

    2022年5月11日
    171
  • 数据库连接池到底应该设多大?这下终于get到了!

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:kelgon www.jianshu.com/p/a8f653fc0c54 本文内容95%译自这篇文章: ht…

    2021年6月28日
    129

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号