使用VUEJS2.0製做音樂播放器

研究了2天的成果終於獲得回報了,播放器已經制做完成,但還有待於完善。我老是離不開jQuery的DOM操做,剛開始學習VUE,仍是會常常使用到DOM操做。所以寫出來的代碼仍是有不少缺點,等待日後學習的差很少了,我會再改進的。
作播放器的想法來源於以前本人作的web app《vuejs2 + wp-rest-api開發web app》此文章的靈感。所以再獻上一個music player來溫習下vue。php

1、效果

GIF動圖有3M多,若是沒有顯示出來,請再等等
vue-player.gifcss

看到了吧,本身的一點小創意,搞了個豬頭上去。html

2、相關代碼

本程序中僅使用了vue的ajax框架vue-resource,未使用到vue-router,所以再安裝vue-cli的時候,能夠略過vue-router,本程序僅有一個組件,即只有一個vue文件,使用了css預處理語言stylus。使用的json數據爲本站相關php代碼生成的(僅爲了演示),若是你是在本地搭建環境,json也能夠寫在本地。
本demo已經使用cordova製做成了安卓的apk文件,如需體驗,請點擊此處下載
源碼已經提交到github(記得給我加星哦):https://github.com/king2088/v...
演示地址:http://www.egtch.com/t_works/...vue

一、生成json的php以下(代碼很是簡單,就是定義一串json數據,而後在展示出來):ios

<?php
    header("Access-Control-Allow-Origin: *");//設置跨域容許
    header('Content-Type: text/html; charset=utf-8'); //設置頁面編碼
    header('Content-type: application/json');//設置頁面爲json格式的文檔

    $data =' {"music":[
        {
          "id":"1",
          "name": "Apologize",
          "singer":"Timbaland Remix",
          "img":"http://www.egtch.com/t_works/Vuedata/apologize.jpg",
          "url": "http://www.egtch.com/t_works/Vuedata/Apologize (Timbaland Remix).mp3"
        },
        {
          "id":"2",
          "name": "Hero",
          "singer":"Enrique Iglesias",
          "img":"http://www.egtch.com/t_works/Vuedata/hero.jpg",
          "url": "http://www.egtch.com/t_works/Vuedata/Hero.mp3"
        },
        {
          "id":"3",
          "name": "I AM YOU",
          "singer":"Kim Taylor",
          "img":"http://www.egtch.com/t_works/Vuedata/iamyou.jpg",
          "url": "http://www.egtch.com/t_works/Vuedata/I Am You.mp3"
        }
      ]}';
    echo $data
?>

二、app.vue代碼git

<template>
  <div id="app">
    <div class="list"><span>{{music.name}}-{{music.singer}}</span><a @click="isShow(),isBg()"><img src="./assets/player/list.png" alt=""></a></div>
    <div class="music">
      <div class="text">{{music.name}}<span>{{music.singer}}</span></div>
      <div class="img"><img id="pic" :src="music.img"></div>
    </div>
    <div class="player">
      <div class="ico"><img src="./assets/player/backward.png" id="pre" @click="isPre"></div>
      <div class="ico"><img src="./assets/player/play.png" id="play" @click="isPlay"><img src="./assets/player/pause.png" id="stop" @click="isStop"></div>
      <div class="ico"><img src="./assets/player/forward.png" id="next" @click="isNext"></div>
    </div>
    <audio id="audio" :src="music.url" preload autoplay @ended="isNext"></audio>
    <transition name="fade">
      <div class="songList" v-show="showList">
         <div class="items">
           <div class="title">歌曲列表 <span id="close" @click="isClose"><img src="./assets/player/close.png"></span></div>
           <div class="item" v-for="(item, index) in MList">
             <a :id="'item-'+index" @click="clickSong(index)">
               <span class="l">{{MList[index].name}}</span>
               <span class="r">{{MList[index].singer}}</span>
               <div class="clear"></div>
             </a>
           </div>
         </div>
       </div>
    </transition>
  </div>
</template>

<script>
export default {
    name: 'app',
    data(){
        return{
         apiUrl: 'http://www.egtch.com/t_works/Vuedata/data.php',
             id: 0,
             bg:'',
          music: '',
          MList:'',
       showList: false
        }
    },
    created(){
        this.getMusic(this.id)
        this.isBg()
    },
    watch:{
        'id':'getMusic',
        'bg':'isBg'
    },
    methods:{
        getMusic(p){
            this.$http.get(this.apiUrl).then(response => {
                // get body data
                response = response.body
                this.MList = response.music
                /*alert(this.MList)*/
                if(p < response.music.length) {
                   this.music = response.music[p]
               }
               if(p > response.music.length){
                    this.id = 0
                    this.music = response.music[this.id]
                }
                if(p < 0){
                   this.id = response.music.length
                   this.music = response.music[this.id]
               }
           })
       },
       /*查看當前audio是否正在播放,若是中止,那麼播放下一曲*/

       isPlay(){
         document.getElementById("audio").play();
         document.getElementById("play").style.display="none";
         document.getElementById("stop").style.display="inline";
         document.getElementById("pic").style.animationPlayState="running";
         return false
       },
       isStop(){
          document.getElementById("audio").pause();
          document.getElementById("stop").style.display="none";
          document.getElementById("play").style.display="inline";
          document.getElementById("pic").style.animationPlayState="paused";
          return false
       },
       isNext(){
           this.id++;
           /*爲了防止中止狀態下,點擊下一曲的時候,中止圖標不出現,而且專輯圖片不轉動*/
           document.getElementById("play").style.display="none";
           document.getElementById("stop").style.display="inline";
           document.getElementById("item-"+this.bg).style.background='none';
           document.getElementById("pic").style.animationPlayState="running";
       },
       isPre(){
           this.id--;
           document.getElementById("play").style.display="none";
           document.getElementById("stop").style.display="inline";
           document.getElementById("pic").style.animationPlayState="running";
       },
       isShow(){
           this.showList = true
       },
       isClose(){
           this.showList = false
       },
       isBg(){
           this.bg = this.id
           document.getElementById("item-"+this.bg).style.background='#F2F2F2';
       },
       /*點擊列表中的歌曲,並播放*/
       clickSong(i){
           this.id = i;
           document.getElementById("item-"+this.bg).style.background='none';
           document.getElementById("play").style.display="none";
           document.getElementById("pic").style.animationPlayState="running";
           this.isBg()
       }
   }
}
</script>

<style lang="stylus" rel="stylesheet/stylus">
html,body
  height 100%
  width 100%
  max-width 600px
  margin 0 auto
  .clear
    clear both
  #app
    font-family 'Microsoft YaHei','\5FAE\8F6F\96C5\9ED1'
    font-weight lighter
    -webkit-font-smoothing antialiased
    -moz-osx-font-smoothing grayscale
    color #2c3e50
    height 100%
    width 100%
    overflow hidden
    .list
      width 100%
      height 60px
      line-height 60px
      background #F2F2F2
      border-bottom 1px #333 solid
      span
        padding-left 20px
        display inline-block
        color darkblue
      & > a
       display block
       float right
       & > img
         margin-top 8px
         width 40px
   .player
     width 100%
     max-width 600px
     height 30%
     opacity .8
     position fixed
     background #F2F2F2
     border-top 3px #000 solid
     border-bottom 10px brown solid
     bottom 0
     font-size 0
     border-top-left-radius 50%
     border-top-right-radius 50%
     text-align center
     display flex
     .ico
       flex 1
       padding-top 50px
       text-align center
       #play
         width 60%
         max-width 64px
         margin-top 35px
         display none
       #stop
         margin-top 35px
         width 60%
         max-width 64px
       & > img
         border 0
         width 32px
         vertical-align middle
   .music
     width 100%
     height 100%
     background url("./assets/player/bg.jpg")
     position relative
     top 0
     left 0
     .text
       width 100%
       text-align center
       padding-top 5%
       font-size 30px
       span
         font-size 14px
         display block
         line-height 2
     .img
       width 200px
       height 200px
       border-radius 50%
       background #333
       margin 0 auto
       position absolute
       outline none
       bottom 46%
       left 50%
       transform translateX(-100px)
       & > img
         width 90%
         height 90%
         padding 5%
         border-radius 50%
         animation: rotation 10s linear infinite;
          -moz-animation: rotation 10s linear infinite;
          -webkit-animation: rotation 10s linear infinite;
          -o-animation: rotation 10s linear infinite;
    .songList
      position: fixed;
      top: 0;
      z-index: 100;
      width: 100%;
      max-width 600px
      margin 0 auto
      height: 100%;
      overflow: auto;
      transition: all .5s;
      background: rgba(7, 17, 27, .4);
      backdrop-filter: blur(10px); /*ios 模糊背景*/
      .items
        background #ffffff
        width 100%
        height 55%
        margin 0 auto
        padding 60px 0 0 0
        overflow auto
        border-bottom 2px #000 solid
        .title
          width 100%
          max-width 600px
          height 50px
          line-height 50px
          background #FFF
          border-bottom 1px #DDD solid
          text-align center
          padding-top 10px
          font-size 18px
          position fixed
          top 0
          #close
            float right
            width 40px
            & > img
             width 40px
       .item
         width 100%
         margin 0 auto
         border-top 1px #EEE solid
         line-height 2
         & > a
           color black
           padding 8px 5%
           display block
           width 90%
           & > span
             display inline-block
             width 50%
           .l
             float left
             font-size 16px
           .r
             float right
             text-align right
             font-size 12px
             color #CCC
 @-webkit-keyframes rotation
   from
     transform rotate(0deg)
   to
     -webkit-transform rotate(360deg)
 .fade-enter-active
   transition all .3s ease
 .fade-leave-active
   transition all .3s cubic-bezier(1.0, 0.5, 0.8, 1.0)
 .fade-enter, .fade-leave-active
   transform translateY(-20px)
   opacity 0
</style>
相關文章
相關標籤/搜索