一个 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

部分功能预览

相关推荐
键盘鼓手苏苏几秒前
Flutter for OpenHarmony:markdown 纯 Dart 解析引擎(将文本转化为结构化 HTML/UI) 深度解析与鸿蒙适配指南
前端·网络·算法·flutter·ui·html·harmonyos
芭拉拉小魔仙6 小时前
企业级Vue项目的状态管理:从原理到实战架构
前端·vue.js·架构
恋猫de小郭6 小时前
丰田正在使用 Flutter 开发游戏引擎 Fluorite
android·前端·flutter
扶苏10027 小时前
Vue 3 响应式原理深度解析
前端·javascript·vue.js
NEXT067 小时前
React 性能优化:图片懒加载
前端·react.js·面试
PineappleCoder7 小时前
别让字体拖了后腿:FOIT/FOUT 深度解析与字体加载优化全攻略
前端·性能优化
NEXT067 小时前
后端跑路了怎么办?前端工程师用 Mock.js 自救实录
前端·后端·程序员
装不满的克莱因瓶9 小时前
Java7新特性:try-with-resources写法
java·前端·javascript·jdk·新特性·jdk7
SailingCoder10 小时前
【 从“打补丁“到“换思路“ 】一次企业级 AI Agent 的架构拐点
大数据·前端·人工智能·面试·架构·agent
~央千澈~10 小时前
抖音弹幕游戏开发之第12集:添加冷却时间机制·优雅草云桧·卓伊凡
java·服务器·前端