评论

小程序web-view关闭后,页面音频没有关闭

在web-view的src中,引入了一个HTML5页面,这个页面有个自动播放的音频。

问题描述:

web-view的src中,引入了一个HTML5页面,这个页面有个自动播放的音频。
在小程序中,点击右上角关闭小程序后,web-view页面中的音频依然会播放。

期待现象

期待关闭小程序之后,音频也停止。

通过查找文档,发现没有直接提供方法,网上找了一圈之后,尝试的方案也都无法实现。

所以我这里想到的思路是,当用户关闭小程序时,应该销毁掉web-view。可惜,目前没有这个接口。

所以我就利用了模拟的方式来实现,当前小程序页面onHide时,就将web-view的页面src属性清空。

后来经过测试发现,在ios平台下,需要制定一个url,在android平台下只需要清空。另外为了防止造成缓存,给url后面添加了一个随机的参数。

以下是代码片段。

<template>
	<view>
		 <web-view :src="webUrl"></web-view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				webUrl: 'https://demo.com/weixin/index.html'
			}
		},
		onLoad() {
		},
		onHide(){
			// webview关闭后,刷新url。否则会造成音乐在后台继续播放的bug
			if (wx.getSystemInfoSync().platform == "ios") {
				this.webUrl = 'https://demo.com/weixin/index.html?redirect=true';
			}else{
				// android系统下只能给空值
				this.webUrl = ';'
			}
		},
		onBackPress(){
		},
		methods: {
			
		}
	}
</script>

<style>
</style>

注意:

以上代码是通过uni-app开发的。如果在微信开发者工具中编辑,需要符合微信小程序的语法。


2019年6月2日 更新

经过测试,发现以上代码并不是最好的选择。因为当用户隐藏小程序后,在最近使用的小程序中,该小程序会继续在后台保留一段时间。如果是替换web-view的url,会造成音乐继续播放。

另外一个问题就是,我以上代码判断了ios和andorid两个平台。其实现在想来并不需要。

综上所述,以上代码参考意义并不大,请使用监听hashchange 方式来判断。代码如下:

小程序中代码

<view class="page-body">
  <view class="page-section page-section-gap">
    <web-view src="https://demo.com/weixin/index.html#show={{showed}}"></web-view>
  </view>
</view>

Page({
    data: {
        showed: false
    },
    // 小程序在前台
    onShow: function(){
        this.setData({
            showed: true
        });
    },
    // 小程序在后台
    onHide: function() {
        this.setData({
            showed: false
        });
    }
})

web-view中代码

window.addEventListener("hashchange", () => {
		var globalAudio = document.getElementById("player"); //获取audio HTMLDOM
		const hashData = parseURL(window.location.hash.slice(1));
		if (hashData.show) {
			const isShow = hashData.show === 'true';
			if (isShow) { //切到前台
				if (globalAudio.paused) {
					globalAudio.play();
				}
			} else {  //切到后台
				if (globalAudio.play) {
					globalAudio.pause();
				}
			}
		}
	}, false);

  
	function parseURL(e) {
		var t, n, r, i = e, s = {};
		t = i.split("&"),
		r = null,
		n = null;
		for (var o in t) {
			var u = t[o].indexOf("=");
			u !== -1 && (r = t[o].substr(0, u),
			n = t[o].substr(u + 1),
			s[r] = n)
		}
		return s
	}

** 总结 **

  • 通过onShowonHide设置属性showed的值,来判断用户的小程序是在前台还是后台。
  • 因为是给web-viewsrc动态修改hash值,所以不会造成页面刷新,相比直接修改src会更好。
  • 然后在web-view所在的页面中,监听hashchange事件,在事件中,判断hash属性showtrue false值,空值音乐的暂停与播放。

2019年6月6日 更新

本来以为监听hash值的变化,已经是能完美的解决这个问题了。但是经过测试之后,发现了严重的问题:安卓系统下,用户点击物理返回按键,会无法退出小程序

这个问题造成的原因是:每次修改hash值时候,都会添加一条历史浏览记录。而用户点击返回按钮时,就相当于点击浏览器的返回按钮。自然就是会返回多次才能回到第一页,然后才退出掉小程序。

这样的话,用户体验就非常不好。我首先想到的是,调用wx.miniProgram.navigateBack,直接返回。但是会报一个错误:

意思就是说,我当前的web-view是第一页,不能再返回了。

最后还是通过阅读微信文档,发现了onPageStateChange这个监听事件。可以判断微信小程序是否在前台。我最开始的时候,测试过这个接口,当时当时微信客户端没有升级,所以我一直以为这个接口是不能用的呢。

其实这个接口是完全可以用的。只不过需要微信版本在7.0.3

这样的话,就可以将代码优化得非常少了。

// wxml
<view>
    <web-view src="https://demo.com/weixin/index.html"></web-view>
</view>
// 微信中的js
Page({
   
})
// web-view页面中的js
wx.ready(function() {
        var globalAudio = document.getElementById("player"); //获取audio HTMLDOM
		WeixinJSBridge.on('onPageStateChange', function(res) {
            // 注意:res.active返回的是字符串类型的true和false
			if(res.active == 'true'){
				globalAudio.play();
			}else{
				globalAudio.pause();
			}
		});
		
});	

主要就是,不在采用监听hash值的变化了,直接使用微信提供的接口。非常好用。

最后一次编辑于  2019-06-06  
点赞 3
收藏
评论

7 个评论

  • Perry
    Perry
    2019-05-30

    顶一下

    2019-05-30
    赞同 1
    回复 1
    • 爱上猫儿的鱼
      爱上猫儿的鱼
      2019-06-02

      之前的方式不对,修改了一下。

      2019-06-02
      回复
  • 🎈JaimeCheng
    🎈JaimeCheng
    2021-08-31
    请问下WeixinJSBridge.on('onPageStateChange',这个方法我为什么一直触发不到啊
    
    2021-08-31
    赞同
    回复
  • ...
    ...
    2019-10-23

    我的Audio 不能自动播放,请问你是怎么自动播放的

    2019-10-23
    赞同
    回复
  • 2019-09-10

    onPageStateChange 这个方法是在那个文档里的..测试里下提示没有这个方法

    2019-09-10
    赞同
    回复
  • 大我Warmie
    大我Warmie
    2019-06-04

    如果 web-view中代码  没有权限去改    这个方法还能使用吗

    2019-06-04
    赞同
    回复 1
    • 爱上猫儿的鱼
      爱上猫儿的鱼
      2019-06-05

      那应该是不能的了。

      2019-06-05
      回复
  • 阿巴阿巴
    阿巴阿巴
    2019-06-01

    暂没重现。我也用到这种实现方式

    2019-06-01
    赞同
    回复 1
    • 爱上猫儿的鱼
      爱上猫儿的鱼
      2019-06-02

      之前的方法不对,修改了下,请注意。

      2019-06-02
      回复
  • ℋღ᭄朱事顺心💗࿐
    ℋღ᭄朱事顺心💗࿐
    2019-05-31

    试试在网页bady标签添加onunload监听,关闭音频看看

    2019-05-31
    赞同
    回复 2
    • 爱上猫儿的鱼
      爱上猫儿的鱼
      2019-05-31

      监听事件的方式,网上也有提到。我尝试过,均不可以。

      2019-05-31
      回复
    • 爱上猫儿的鱼
      爱上猫儿的鱼
      2019-06-02

      试试监听`hash`值吧。

      2019-06-02
      回复
登录 后发表内容