zoukankan      html  css  js  c++  java
  • 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();
        });
    }
  • 相关阅读:
    什么是守护线程?
    如何优雅地停止一个线程?
    如何创建、启动 Java 线程?
    什么是线程?什么是进程?为什么要有线程?有什么关系与区别?
    并行是什么意思?与并发的区别是什么?
    并发编程的缺点?
    BZOJ_3058_四叶草魔杖_kruscal+状压DP
    BZOJ_3476_[Usaco2014 Mar]The Lazy Cow_扫描线+切比雪夫距离
    BZOJ_1511_[POI2006]OKR-Periods of Words_KMP
    BZOJ_3479_[Usaco2014 Mar]Watering the Fields_Prim
  • 原文地址:https://www.cnblogs.com/zjianfei/p/15683048.html
Copyright © 2011-2022 走看看