一个 React 简易网页端音乐播放器

前言

这是一个轻量级的 react 音乐播放器,前端使用 UmiJS,后端采用网易云音乐 NODEJS API 制作。项目的 TS 声明写的比较乱,后续有空的话会发布重写 TS 的版本或者直接重构该播放器。

后续计划将右侧播放器抽离为一个单独的组件,可供页面直接使用。

功能

现有功能

  1. 登陆 / 退出个人网易云账号
  2. 获取私人雷达歌单
  3. 播放歌曲
  4. 播放自己已有的网易云音乐歌单 / 订阅的歌单
  5. 单曲播放 / 全部循环 / 随机播放
  6. 搜索歌曲
  7. 背景图切换

计划中功能(先把饼画着)

  1. 音质选择
  2. 歌曲切换 -> 背景图变化
  3. 保存播放列表并同步到网易云
  4. 双语歌词对照
  5. 歌词自定义字体大小
  6. 歌曲查看评论 / 点赞 / 留言
  7. 详情页相似歌曲推荐
  8. 无版权歌曲或加载出错歌曲增加标记
  9. 将右侧播放器抽离成独立组件

比较有特色的地方

1、右侧全局播放栏

播放栏可以清空播放列表,查看当前歌曲歌词,对播放列表的歌曲可以使用拖拽进行顺序调整。

2、主页左上角频谱图的实现

开始构建使用

1.安装项目

js 复制代码
npm install

2.设置后台接口地址

第一个:网易云 NODEJS 服务器,到 src/utils/request.ts 将其设置为你的网易云后台 API 地址。

js 复制代码
switch (process.env.NODE_ENV) {
  case 'production':
    // 你的生产环境地址 / Your production mode api
    axios.defaults.baseURL = '';
    break;

  default:
    // development
    axios.defaults.baseURL = 'http://localhost:3000';
    break;
}

第二个:天气地址,到 src/constant/api/weather.ts 进行设置。

然后到 src/redux/modules/Weather/action.ts 下根据你设置的天气接口改变传入数据结构,文件内均有注释。

js 复制代码
      const info = {
        // 空气质量
        airQuailty: dewPt,
        // 当前气温
        currentTemp: temp,
        // 体感气温
        feelTemp: feels,
        // 湿度
        humidity: rh,
        // 气压
        baro,
        // 天气描述,如晴或多云
        weatherDescription: cap,
      }

如果想高度自定义样式或内容的话可以到 src/pages/IndexPage/topRightWeather 进行调整。

打包发布

js 复制代码
npm run build

部分功能预览

相关推荐
周淳APP几秒前
【React Hook全家桶】大致过一遍React Hooks
前端·javascript·react.js·前端框架·react hooks
sheji34163 分钟前
【开题答辩全过程】以 基于web的图书借阅系统的设计与实现为例,包含答辩的问题和答案
前端
CodeSheep8 分钟前
两位大佬相继离世,AI时代我们活得太着急了
前端·后端·程序员
xuankuxiaoyao10 分钟前
VUE.JS 实践 第三章
前端·javascript·vue.js
放下华子我只抽RuiKe523 分钟前
NLP自然语言处理硬核实战笔记
前端·人工智能·机器学习·自然语言处理·开源·集成学习·easyui
PieroPc23 分钟前
电脑DIY组装报价系统 用MiMo V2 Pro 写html ,再用opencode(选MiMo 作模型) 当录入口
前端·html
工程师老罗26 分钟前
lvgl有哪些布局?
前端·javascript·html
好家伙VCC28 分钟前
# 发散创新:用Selenium实现自动化测试的智能断言与异常处理策略在现代Web应用开发中,*
java·前端·python·selenium
关中老四40 分钟前
【原生JS甘特图MZGantt 】如何给父任务设置独立进度条
前端·javascript·甘特图
英俊潇洒美少年42 分钟前
react 18 的fiber算法
前端·算法·react.js