国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js微信應用場景之微信音樂相冊案例分享

2019-11-19 15:49:51
字體:
來源:轉載
供稿:網友

這個demo只是一個js微信音樂相冊案例大概思路,具體還需要根據情況來進行

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">  <title>Document</title>  <link rel="stylesheet" href="reset.css" rel="external nofollow" >  <link rel="stylesheet" href="swiper.min.css" rel="external nofollow" >  <link rel="stylesheet" type="text/css" href="animate.css" rel="external nofollow" >  <style>    html,body{      width:100%;      height:100%;      overflow:hidden;    }    html{      font-size:100px;/*設計稿640*960*/    }    .main,.swiper-container,.swiper-slide{      width:100%;      height:100%;      overflow:hidden;    }    .page1{      position:relative;      background:url("../img/swiper/bg1.jpg") no-repeat;      background-size:cover;    }    .page1 img{      position:absolute;        opacity:0;        }    .page1 img:nth-child(1){      left:2rem;      top:.28rem;      width:.96rem;      height:2.32rem;              }    .page1 img:nth-child(2){      right:0;      top:.28rem;      width:3.7rem;      height:6rem;          }    .page1 img:nth-child(3){      left:.5rem;      bottom:.8rem;      width:5.5rem;      height:5.12rem;          }    .page1 img:nth-child(4){      left:-1.6rem;      bottom:0;      width:7.86rem;      height:5.88rem;          }    /*實現切換完成后頁面中的元素在開始運動的思想:開始的時候當前的這個區域沒有對應的ID,當切換到這個區域的時候,我們為其增加ID,在css中我們把所有的動畫效果都放在指定的ID下,這樣的話只需要讓區域有ID,里面的子元素就有動畫了*/    #page1 img:nth-child(1){      /*注意移動端的樣式寫兩套 并且不加webkit的在后*/      -webkit-animation:bounceInLeft 1s linear 0s 1 both;      animation:bounceInLeft 1s linear 0s 1 both;      }    #page1 img:nth-child(2){      /*注意移動端的樣式寫兩套 并且不加webkit的在后*/      -webkit-animation:bounceInRight 1s linear .3s 1 both;      animation:bounceInRight 1s linear .3s 1 both;      }    #page1 img:nth-child(3){      /*注意移動端的樣式寫兩套 并且不加webkit的在后*/      -webkit-animation:bounceInUp 1s linear .6s 1 both;      animation:bounceInUp 1s linear .6s 1 both;      }    #page1 img:nth-child(4){      /*注意移動端的樣式寫兩套 并且不加webkit的在后*/      -webkit-animation:bounceInUp 1s linear .9s 1 both;      animation:bounceInUp 1s linear .9s 1 both;      }    .page2{      position:relative;      background:url("../img/swiper/bg2.jpg") no-repeat;      background-size:cover;    }    .page2 img{      position:absolute;      top:2.5rem;      opacity:0;    }    .page2 img:nth-child(1){      top:0;      left:0;      width:3.4rem;      height:1.74rem;    }    .page2 img:nth-child(2){      left:1.48rem;    }    .page2 img:nth-child(3){      left:3.2rem;    }    .page2 img:nth-child(4){      left:4.7rem;    }        #page2 img:nth-child(1){      -webkit-animation:bounceInLeft 1s linear 0s 1 both;      animation:bounceInLeft 1s linear 0s 1 both;      }    #page2 img:nth-child(2){      -webkit-animation:zoomIn 1s linear .3s 1 both;      animation:zoomIn 1s linear .3s 1 both;      }    #page2 img:nth-child(3){      -webkit-animation:zoomIn 1s linear .6s 1 both;      animation:zoomIn 1s linear .6s 1 both;      }    #page2 img:nth-child(4){      -webkit-animation:zoomIn 1s linear .9s 1 both;      animation:zoomIn 1s linear .9s 1 both;      }    .arrow{      position:absolute;      left:50%;      bottom:.2rem;      z-index:10;      margin-left:-.24rem;      width:.48rem;      height:.36rem;      background:url("../img/swiper/web-swipe-tip.png") no-repeat;      background-size:100% 100%;            -webkit-animation:bounce 1s linear 0s infinite both;      animation:bounce 1s linear 0s infinite both;    }    .music{      display:none;      position:absolute;      top:.2rem;      right:.2rem;      z-index:10;      width:.6rem;      height:.6rem;      background:url("../audio/music.svg") no-repeat;      background-size:100% 100%;    }    .music.move{      -webkit-animation :musicMove 1s linear 0s infinite both;      animation :musicMove 1s linear 0s infinite both;    }    .music audio{      display:none;    }    @-webkit-keyframes musicMove{      0%{        -webkit-transform:rotate(0deg);        transform:rotate(0deg);      }      100%{        -webkit-transform:rotate(360deg);        transform:rotate(360deg);      }    }    @keyframes musicMove{      0%{        -webkit-transform:rotate(0deg);        transform:rotate(0deg);      }      100%{        -webkit-transform:rotate(360deg);        transform:rotate(360deg);      }    }  </style></head><body>  <section class='main'>    <!--MUSIC-->    <div class='music' id='musicMenu'>      <audio src="beyond.mp3" preload = 'none' loop autoplay></audio id='musicAudio'>      <!-- <audio>        <source src='beyond.mp3' type='audio/mpeg'/>        <source src='beyond.wav' type='audio/wav'/>        <source src='beyond.ogg' type='audio/ogg'/>      </audio> -->    </div>    <!--CONTAINER-->    <div class='swiper-container'>      <div class='swiper-wrapper'>        <div class='swiper-slide page1'>          <img src="img/swiper/page1-text1.png" alt="">          <img src="img/swiper/page1-text2.png" alt="">          <img src="img/swiper/page1-text3.png" alt="">          <img src="img/swiper/page1-text4.png" alt="">        </div>        <div class='swiper-slide page2'>          <img src="img/swiper/page2-text1.png" alt="">          <img src="img/swiper/page2-text2.png" alt="">          <img src="img/swiper/page2-text3.png" alt="">          <img src="img/swiper/page2-text4.png" alt="">        </div>      </div>    </div>    <!--ARROW-->    <div class='arrow'></div>      </section>  <script charset='utf-8' src='swiper.min.js'></script>  <script>    //rem    ~function(){      var desW = 640,        winW = document.documentElement.clientWidth,        ratio = winW / desW,        oMain = document.querySelector(".main");      if(winW>desW){        oMain.style.margin = "0 auto";        oMain.style.width = desW + 'px';        return;      }      document.documentElement.style.fontSize = ratio*100+"px";    }()    new Swiper('.swiper-container',{      direction:"vertical",      loop:true,      /*當切換結束后,給當前展示的區域添加對應的ID,由此實現對應的動畫效果*/      onSlideChangeEnd:function(swiper){        var slideAry = swiper.slides;//獲取當前一共有多少個活動快(包含loop模式前后多加的兩個)        var curIn = swiper.activeIndex;//當前展示的這個區域的索引        var total = slideAry.length;        //計算ID是PAGE?        var targetId = 'page';        switch(curIn){          case 0:            targetId += total - 2;            break;          case total - 1:            targetId += 1;            break;          default:            targetId += curIn        }        //給當前的活動塊設置ID即可,還要把其余的移除        [].forEach.call(slideAry,function(item,index){          if(curIn === index){            item.id = targetId;            return;          }          item.id = null;        })        slideAry[curIn].id = targetId;        //最后把animate.css里面的動畫to里面添加opacity:1      }    })    //MUSIC    ~function(){      var musicMenu = document.getElementById('musicMenu'),        musicAudio = document.getElementById('musicAudio');      musicMenu.addEventListener('click',function(){        if(musicAudio.paused){          musicAudio.play();          musicMenu.className = "music move";          return;        }        musicAudio.pause();        musicMenu.className = "music";      })      function controlMusic(){        musicAudio.volume = 0.1;        musicAudio.play();        musicAudio.addEventListener('canplay',function(){          musicMenu.style.display = "block";          musicMenu.className = "music move";        })      }      window.setTimeout(controlMusic,1000)    }()  </script></body></html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昌平区| 平度市| 老河口市| 广饶县| 夏津县| 博野县| 呼图壁县| 天峻县| 沾益县| 平塘县| 迭部县| 宁波市| 沈丘县| 山阴县| 兴隆县| 三台县| 仙游县| 吉水县| 图们市| 朝阳市| 霍城县| 蒲城县| 永平县| 大新县| 江源县| 图片| 漳浦县| 西峡县| 清苑县| 古交市| 喜德县| 嵩明县| 盘山县| 无为县| 鸡泽县| 宁远县| 陇南市| 邢台县| 拉萨市| 宁化县| 贵德县|