亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微信小程序音樂播放器開發(fā)

 更新時間:2019年11月20日 15:36:24   作者:前端_李嘉豪  
這篇文章主要為大家詳細介紹了微信小程序音樂播放器開發(fā),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

前言 

這篇文章上一版本是用audio組件開發(fā)的播放器,隨后反應音頻加載速度慢的問題

又用小程序內置的背景音樂播放的方法寫了一遍,邏輯是一樣的邏輯,希望對大家有所幫助!

 <view class='audiosBox'>
  <view class="audioOpen" bindtap="listenerButtonPlay" wx:if="{{!isOpen}}">
   <image class='image2' src="../../images/play.png" />
  </view>
  <view class="audioOpen" bindtap="listenerButtonPause" wx:if="{{isOpen}}">
   <image src="../../images/pauses.png" />
  </view>
  <view class='slid'>
   <slider bindchange="sliderChange" block-size="12px" step="2" value="{{offset}}" max="{{max}}" selected-color="#4c9dee" />
   <view>
    <text class='times'>{{starttime}}</text> <!-- 進度時長 -->
    
    <text class='times'>{{duration}}</text>  <!-- 總時長 -->
   </view>
  </view>
</view>

js部分注意了:bug ios 播放時必須加title 不然會報錯導致音樂不播放

//index.js
//獲取應用實例
const bgMusic = wx.getBackgroundAudioManager()
const app = getApp()
 
Page({
 data: {
  isOpen: false,//播放開關
  starttime: '00:00', //正在播放時長
  duration: '06:41',  //總時長
  src:"http://ws.stream.qqmusic.qq.com/M500001VfvsJ21xFqb.mp3?guid=ffffffff82def4af4b12b3cd9337d5e7&uin=346897220&vkey=6292F51E1E384E061FF02C31F716658E5C81F5594D561F2E88B854E81CAAB7806D5E4F103E55D33C16F3FAC506D1AB172DE8600B37E43FAD&fromtag=46"
 },
 // 播放
 listenerButtonPlay: function () {
  var that = this
  //bug ios 播放時必須加title 不然會報錯導致音樂不播放
  bgMusic.title = '此時此刻' 
  bgMusic.epname = '此時此刻'
  bgMusic.src = that.data.src;
  bgMusic.onTimeUpdate(() => { 
   //bgMusic.duration總時長 bgMusic.currentTime當前進度
   console.log(bgMusic.currentTime)
   var duration = bgMusic.duration; 
   var offset = bgMusic.currentTime; 
   var currentTime = parseInt(bgMusic.currentTime);
   var min = "0" + parseInt(currentTime / 60);
   var max = parseInt(bgMusic.duration);
   var sec = currentTime % 60;
   if (sec < 10) {
    sec = "0" + sec;
   };
   var starttime = min + ':' + sec;  /* 00:00 */
   that.setData({
    offset: currentTime,
    starttime: starttime,
    max: max,
    changePlay: true
   })
  })
  //播放結束
  bgMusic.onEnded(() => {
   that.setData({
    starttime: '00:00',
    isOpen: false,
    offset: 0
   })
   console.log("音樂播放結束");
  })
  bgMusic.play();
  that.setData({
   isOpen: true,
  })
 },
 //暫停播放
 listenerButtonPause(){
   var that = this
  bgMusic.pause()
  that.setData({
   isOpen: false,
  })
 },
 listenerButtonStop(){
  var that = this
  bgMusic.stop()
 },
 // 進度條拖拽
 sliderChange(e) {
  var that = this
  var offset = parseInt(e.detail.value);
  bgMusic.play();
  bgMusic.seek(offset);
  that.setData({
   isOpen: true,
  })
 },
 // 頁面卸載時停止播放
 onUnload() {
  var that = this
  that.listenerButtonStop()//停止播放
  console.log("離開")
 },
})

css部分 

/**index.wxss**/
.audiosBox{
 width: 92%;
 margin: auto;
 height: 130rpx;
 display: flex;
 justify-content: space-between;
 align-items: center;
 background: #f6f7f7;
 border-radius: 10rpx;
}
/*按鈕大小 */
.audioOpen{
 width: 70rpx;
 height: 70rpx;
 border: 2rpx solid #4c9dee;
 border-radius: 50%;
 display: flex;
 align-items: center;
 justify-content: center;
 margin-left: 20rpx;
}
 
image{
 width: 30rpx;
 height: 40rpx;
}
.image2{
 margin-left: 10%;
}
/*進度條長度 */
.slid{
 flex: 1;
 position: relative;
}
.slid view{
 display: flex;
 justify-content: space-between;
}
.slid view>text:nth-child(1){
 color: #4c9dee;
 margin-left:6rpx; 
}
.slid view>text:nth-child(2){
 margin-right:6rpx; 
}
slider{
 width: 520rpx;
 margin: 0;
 margin-left: 35rpx;
}
/*橫向布局 */
.times{
 width: 100rpx;
 text-align: center;
 display: inline-block;
 font-size: 24rpx;
 color:#999999;
 margin-top: 5rpx;
}
.title view{
 text-indent: 2em;
 
}

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

相關文章

  • 優(yōu)化javascript的執(zhí)行速度

    優(yōu)化javascript的執(zhí)行速度

    這個是我在網上找的資料,具體的出處,我已經記不清楚了,覺得很不錯,就和大家分享了
    2010-01-01
  • JS PromiseLike的判定與使用詳解

    JS PromiseLike的判定與使用詳解

    本文主要介紹了JS PromiseLike的判定與使用詳解, 文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-11-11
  • 使用戶點擊后退按鈕使效三行代碼

    使用戶點擊后退按鈕使效三行代碼

    使用戶點擊后退按鈕使效三行代碼...
    2007-07-07
  • JS敏感詞過濾代碼

    JS敏感詞過濾代碼

    本篇文章主要介紹了JS敏感詞過濾實例,詳細的介紹了兩種方法,RegExp(),replace(),具有一定的參考價值,有興趣的可以了解一下。
    2016-12-12
  • JavaScript中的this基本問題實例小結

    JavaScript中的this基本問題實例小結

    這篇文章主要介紹了JavaScript中的this基本問題,結合實例形式總結分析了JavaScript中this的功能、常見用法與操作注意事項,需要的朋友可以參考下
    2020-03-03
  • js實現綠白相間豎向網頁百葉窗動畫切換效果

    js實現綠白相間豎向網頁百葉窗動畫切換效果

    這篇文章主要介紹了js實現綠白相間豎向網頁百葉窗動畫切換效果,實例分析了javascript實現百葉窗動畫效果的技巧,需要的朋友可以參考下
    2015-03-03
  • js實現簡單圖片拖拽效果

    js實現簡單圖片拖拽效果

    這篇文章主要為大家詳細介紹了js實現簡單圖片拖拽效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • 微信小程序報錯: thirdScriptError的錯誤問題

    微信小程序報錯: thirdScriptError的錯誤問題

    這篇文章主要介紹了微信小程序報錯: thirdScriptError,本文給大家分享解決方法,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • 簡單獲取鍵盤的KeyCode

    簡單獲取鍵盤的KeyCode

    簡單獲取鍵盤的KeyCode...
    2006-09-09
  • JavaScript對象轉數組的3種簡單方法小結

    JavaScript對象轉數組的3種簡單方法小結

    在JavaScript中可以通過Object.keys()結合Array.map()、Object.entries()或Object.values()等方法將對象轉換為數組,這些方法各有優(yōu)勢,可根據需要靈活選擇,需要的朋友可以參考下
    2024-09-09

最新評論