用vue+flask做了个音乐播放器(前端部分)

这段时间突然脑子一热打算做一个音乐播放器玩玩,于是就诞生了这个玩意。网页链接在这
在这里插入图片描述

本来只是想做个小小demo玩玩的所以界面就没打算做很好看,于是仿照了悦听的界面进行的优化,后面发现需求变多了搞得本不美观的界面雪上加霜,但是还能接受就浅浅地介绍一下吧,毕竟谁能拒绝一个独属于自己的小玩意呢

前端

这个音乐播放器是由vue加python flask前后端分离搭建的,前端主要向后端发送所要搜索的歌手或者歌曲名,并接收后端传过来的歌词,音乐,以及评论

1.搜索

这里我演示一下搜索周杰伦
在这里插入图片描述

2.播放

播放音乐,接收评论以及歌曲列表后的样子,抓取的评论都qq音乐里最热门的评论,还能对歌曲列表进行删除或者收藏
在这里插入图片描述

3.歌词显示

还有歌词显示
在这里插入图片描述

4.收藏

当你点击爱心之后将会把歌曲放入收藏列表中,并在本地永久保存,这是我的收藏歌单
在这里插入图片描述

5.audio自定义以及换源

并且也对下列的播放器进行了自定义,实现了上下首替换,以及随机,单曲,顺序播放,默认是顺序播放。并且提供了下载功能。
换源
只需要点击logo进行换源即可。但是换源之后无论是歌词还是评论或者歌曲列表都是和另一个源不同的。
在这里插入图片描述
当换源成功后下面源会变成1,并且列表会清空,而且两个源的收藏列表也是不同的。
在这里插入图片描述
这时再搜索一下裹着心的光,就会有惊喜,这里我为了更好展示就用我的收藏列表演示了
在这里插入图片描述
欧克,开始播放了。

6.下载

顺便演示一下下载功能
在这里插入图片描述
因为之前已经下载过了,所以有个(1),格式都是以MP3保存的
前端大概就介绍到这,还有一些界面优化啊等等小细节还没做好所以暂时还没上线。

部分代码

logo及搜索栏
<div class="search_bar">
        <img src="../assets/musicPic/player_title5_1.png" alt="" @click="open1">

        <el-button type="info" class="sc_music" @click="get_Collection">收藏歌单</el-button>
        <el-button type="info" class="ss_music" @click="get_Search">搜索列表</el-button>
        <!-- 搜索歌曲 -->
        <div class="search_input">
          <input type="text" autocomplete="off" v-model="query" @keyup.enter="searchMusic" placeholder="请输入歌名或歌手"
                 class="Music_input">
          <button class="iconfont icon-sousuo" @click="searchMusic"></button>
        </div>
</div>
搜索列表
<div class="song_wrapper"
             v-loading="loading"
             element-loading-text="拼命加载中"
             element-loading-spinner="el-icon-loading"
             element-loading-background="rgba(255, 255, 255, 0.0)">
          <ul class="song_list">
            <li v-for="(item, index) in musicList" :key="index" @mouseover="onMouseover(index)" @mouseout="onMouseleave(index)" :class="{ MusicActivate:isPlaying===true&&musicid === item.id}" @dblclick="playMusic(item.id,item.mid,item.pid,item.name,item.sname)">
              <b :title=item.name>{{ item.name }}</b>
              <span style="width: 70px;margin-right: 0;overflow: hidden">{{ item.sname }}</span>
              <span style="width: auto;margin-bottom: 2px"><i class="iconfont icon-02" style="color: #fa048d" @click="setColl(item)"></i></span>
              <span  class="del-btn" style="width: auto;margin-bottom: 2px" ><i v-show="showDel&&n===index" class="iconfont icon-shanchu" @click="delMusic(index)"></i></span>
            </li>
          </ul>
          <img src="../assets/musicPic/line.png" class="switch_btn" alt="">
</div>
中间封面及歌词
<!-- 歌曲信息容器 -->
        <div class="player_con" :class="{playing:isPlaying}" v-show="showdisc">
          <img src="../assets/musicPic/player_bar.png" class="play_bar"/>
          <!-- 黑胶碟片 -->
          <div @click="LyricorPic">
            <img src="../assets/musicPic/disc.png" class="disc autoRotate"/>
            <img :src="musicCover" class="cover autoRotate"/>
          </div>
        </div>
        <!-- 歌词显示容器 -->
        <transition
          name="custom-classes-transition"
          enter-active-class="animate__animated animate__tada"
          leave-active-class="animate__animated animate__bounceOutRight"
        >
          <div class="play_lyric" @click="showBar" v-show="showLyric">
            <el-col type="flex" justify="center" class="lyric-contain">
              <ul class="lyric_list" ref="lyric_list">
                {{ getAllKey }}
                <li
                  :class="{ 'active':key < currentTime }"
                  v-for="(item,key,index) in musicLyric" :key="index"
                  class="lyric-row">
                  {{ item }}{{ srcollLrc(key, index) }}
                </li>
              </ul>
            </el-col>
          </div>
        </transition>
留言部分
<!-- 评论容器 -->
        <div class="comment_wrapper"
             v-loading="loadings"
             element-loading-text="拼命加载中"
             element-loading-spinner="el-icon-loading"
             element-loading-background="rgba(255, 255, 255, 0.0)">
          <h5 class='title'>热门留言</h5>
          <div class='comment_list'>
            <dl v-for="item in hotComments">
              <dt><img :src="item.Avatar" alt=""></dt>
              <dd class="name">{{ item.Nick }}</dd>
              <dd class="detail">
                {{ item.Content }}
              </dd>
              <dl v-for="sub in item.SubComments">
                <dt><img :src="sub.Avatar"></dt>
                <dd class="name">{{ sub.Nick }}</dd>
                <dd class="detail">
                  {{ sub.Content }}
                </dd>
              </dl>
            </dl>
          </div>
          <img src="../assets/musicPic/line.png" class="right_line">
        </div>
      </div>
自定义audio部分
<!-- 自定义audio -->
      <div class="audio_con">
        <audio ref='audio' @ended="end" @play="playFunc" @pause="pauseFunc" :src="musicUrl" class="myaudio"
               @timeupdate="timeupdateFunc"
               @canplay="canplayFunc"
               @error="errorFunc"></audio>
        <div class="audio_control">
          <div class="play_control">
             <span
               class="audioSpan"
               @click="clickFunc('backward')"
               style="width: 10px; height: 20px; "
             ><i class="el-icon-d-arrow-left" aria-hidden="true"></i
             ></span>
            <span
              class="audioSpan"
              @click="clickFunc('play')"
              v-show="!isPlaying"
              style="width: 10px;margin-left: 30px"
            ><i class="el-icon-video-play" aria-hidden="true"></i
            ></span>
            <span
              class="audioSpan"
              @click="clickFunc('pause')"
              v-show="isPlaying"
              style="width: 10px;margin-left: 30px"
            ><i class="el-icon-video-pause" aria-hidden="true"></i
            ></span>
            <span
              class="audioSpan"
              @click="clickFunc('forward')"
              style="width: 10px;margin-left: 30px"
            ><i class="el-icon-d-arrow-right" aria-hidden="true"></i
            ></span>
            <div
              style="display: block; align-items: center;margin-left: 60px; margin-top: 0px;position: relative"
              @mousedown="isDraging = true"
              @mouseup="isDraging = false"
              class="audio_slider">
              <div style="width: auto; top:0; position: absolute; font-size: 10px;margin-left: 20px">
                {{ title }}--{{ artist }}
              </div>
              <div style="font-size: 10px;position: absolute;top:0;left: 430px;">
                {{ formatCurrentTime }}/{{ formatDuration }}
              </div>
              <el-slider
                v-model="playProcess"
                class="sliderClass"
                style="width: 500px;margin-top: 10px"
                @change="setProcessFunc"
                :format-tooltip="formatTooltip"
              ></el-slider>
            </div>
            <span
              class="audioSpan"
              @click="changeMode"
              style="width: 10px;margin-left: 30px;font-size: 20px;margin-top: 10px;cursor: pointer"
            ><i :class=iconMode() aria-hidden="true" style="font-weight: bolder"></i
            ></span>
            <span class="audioVolSpan" style="width: 10px;margin-left: 30px;font-size: 20px;margin-top: 10px"
            ><i class="el-icon-microphone" aria-hidden="true"></i
            ></span>
            <el-slider
              v-model="playVolume"
              style="margin-left: 15px;margin-top: 5px;width: 80px;"
              class="sliderVolumClass"
              :format-tooltip="formatTooltipVol"
              @change="setVolumeFunc"
            ></el-slider>
            <a class="iconfont icon-xiazai" style="font-size: 25px;margin-top: 5px;margin-left: 30px" @click="downloadMusic(musicUrl,title)"></a>
          </div>
        </div>
      </div>

总结

其余代码就不一一展示,优化也没完全完成所有还没在GitHub开源如果你对这个项目感兴趣或者想拿来玩玩可以私信我。因为后端涉及爬虫部分我也不知道会不会被限所以分开两篇进行介绍。过了过了,后端在这

  • 11
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Aasee.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值