ios端微信浏览器中自动播放HTML5的audio问题

前言

方法一:JS-SDK

核心原理: 在微信的JS-API 中 play 一下 audio 即可达到自动播放的目的(应该是微信自己做了处理)

引入文件后,首先通过wx.config接口注入权限验证配置,然后在ready中play一下audio。

<!--  当使用方法1时必须加载 JS-SDK 的 JS 文件  -->
<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>

<script>
   function autoPlayAudio1() {
        wx.config({
            // 配置信息, 即使不正确也能使用 wx.ready
            debug: false,
            appId: '',
            timestamp: 1,
            nonceStr: '',
            signature: '',
            jsApiList: []
        });
        wx.ready(function() {
           let audio = document.createElement('audio'); //生成一个audio元素 
           audio.src = 'https://freetyst.nf.migu.cn/public/product08/2018/03/06/2012%E5%B9%B402%E6%9C%8820%E6%97%A5%E6%B5%B7%E8%9D%B6%E5%86%85%E5%AE%B9%E5%87%86%E5%85%A59%E9%A6%96/%E5%85%A8%E6%9B%B2%E8%AF%95%E5%90%AC/Mp3_64_22_16/%E5%BA%90%E5%B7%9E%E6%9C%88-%E8%AE%B8%E5%B5%A9.mp3';
           audio.play();   // 自动播放
        });
    }
</script>

vue-cli 脚手架代码:

router.afterEach((to, from, next) => {
    let wx = Vue.prototype.$wechat;
    let _url = window.location.href.split('#')[0];
    // 使用JS-SDK的页面必须先注入配置信息
    Vue.prototype.$http('/mobile/wechat/jsconfig?url=' + encodeURIComponent(_url)).then(res => {
      if (res.status) {
        // 注入配置
        Vue.prototype.$wechat.initConfig(res.data);
      }
    })
    wx.ready(() => {
      let audio = document.createElement('audio'); // 生成一个audio元素 
      audio.src = 'https://freetyst.nf.migu.cn/public/product08/2018/03/06/2012%E5%B9%B402%E6%9C%8820%E6%97%A5%E6%B5%B7%E8%9D%B6%E5%86%85%E5%AE%B9%E5%87%86%E5%85%A59%E9%A6%96/%E5%85%A8%E6%9B%B2%E8%AF%95%E5%90%AC/Mp3_64_22_16/%E5%BA%90%E5%B7%9E%E6%9C%88-%E8%AE%B8%E5%B5%A9.mp3';
      audio.play(); // 自动播放
   })
})

注意事项:

1、wx.ready 好像一定要放在main.js中的wx.config()之后执行

方法二:WeixinJSBridge.invoke

以前用的是WeixinJSBridge.invoke方法,绑定getNetworkType事件,返回中拿到网络信息,然后在根据网络信息是wifi还是4G等来播放音频。

mounted() {
    alert(typeof WeixinJSBridge);
    WeixinJSBridge.invoke('getNetworkType', {}, (e) => {
    alert(e.err_msg); // 在这里拿到 e.err_msg, 这里面就包含了所有的网络类型
    let audio = document.createElement('audio'); //生成一个audio元素
    audio.src = 'https://freetyst.nf.migu.cn/public/product08/2018/03/06/2012%E5%B9%B402%E6%9C%8820%E6%97%A5%E6%B5%B7%E8%9D%B6%E5%86%85%E5%AE%B9%E5%87%86%E5%85%A59%E9%A6%96/%E5%85%A8%E6%9B%B2%E8%AF%95%E5%90%AC/Mp3_64_22_16/%E5%BA%90%E5%B7%9E%E6%9C%88-%E8%AE%B8%E5%B5%A9.mp3';
    // 自动播放
    audio.play();
    });
}
posted @ 2021-12-13 13:57  小阿飞ZJF  阅读(445)  评论(0编辑  收藏  举报