微信小程序实现音频播放

废话不多说直接上代码,亲测可用

Page({
  data: {
    isPlay: false,
  },
  onLoad() {
    this.audioPlay()
  },
  //创建语音示例进行播放
  createAudio(e) {
    //创建内部 audio 上下文 InnerAudioContext 对象。
    this.innerAudioContext = wx.createInnerAudioContext();
    // 发生错误触发
    this.innerAudioContext.onError(function (res) {})
    //设置音频地址
    this.innerAudioContext.src = "https://www.cambridgeenglish.org/images/153149-movers-sample-listening-test-vol2.mp3"
  },
  //播放
  audioPlay() {
    this.createAudio();
    //播放音频
    this.innerAudioContext.play();
    //设置当前播放按钮状态切换
    this.setData({
      isPlay: true
    })
  },
  // 停止播放
  audioPause() {
    //设置当前播放按钮状态切换
    this.setData({
      isPlay: false
    })
    //暂停音频 
    this.innerAudioContext.pause();

  },
  // 结束音频
  end: function (e) {
    //暂停音频 
    this.innerAudioContext.pause();
  },
  onHide: function () {
    // 结束音频
    this.end();
  },
  onUnload: function () {
    // 结束音频
    this.end();
  },
})

也可以直接封装在工具函数中进行播放

    //创建内部 audio 上下文 InnerAudioContext 对象,音频对象放在顶部,防止多个音频一块播放
    const innerAudioContext = wx.createInnerAudioContext();
    module.exports = {
      // 音频播放
      audioPlay(url = "https://www.cambridgeenglish.org/images/153149-movers-sample-listening-test-vol2.mp3") {
        innerAudioContext && innerAudioContext.pause();
        // 发生错误触发
        innerAudioContext.onError(function (res) {})
        //设置音频地址
        innerAudioContext.src = url;
        innerAudioContext.play();
      }
    }```

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

前端J先生

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

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

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

打赏作者

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

抵扣说明:

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

余额充值