评论

[填坑手册]小程序web-view组件实战与踩坑

小小web-view,大大真滋味

首先,根据官网文档可以知道 只有非个人 的小程序才可以使用web-view组件,如果你的个人开发者,可以跳过这篇文章。

一、使用web-view以及它的好处

1、己方账号(第三方)与小程序openId/UnionId的关联绑定,实现免登陆

比如你是某门户网站S,你要识别自己小程序上的用户与网站用户的关系,你可以通过三种方法绑定关系,公众号,小程序源生,小程序web-view内嵌跳转三种方法

2、内嵌H5的富文本,减少重复开发

比如你是门户网站,社区,以往有大量的新闻和帖子,里面带了各种css样式的富文本,小程序源生是无法直接读取的,需要大量转化,这时候直接内嵌这些H5新闻,大大降低开发成本

3、热更新,减少发布审核

某些需要经常更新的内容、公告、活动页,内嵌H5可以减少频繁提交小程序审核

二、小程序功能赋权

为H5提供各种小程序才有的功能,比如录音,扫一扫等。

注意事项

  1. 多场景判断,建议使用官方API: wx.miniProgram.getEnv
  2. H5唤醒一些小程序API有一定的延时,0.3~1秒
  3. 请调用小程序专用的JSSDK,同一个jssdk,但是webview的功能收到限制,和之前微信打开H5有所不同
  4. 小程序自动获取加载H5的title
  5. H5中iframe的url必须也是业务域名
  6. web-view一定是撑满全屏的,自定义顶部菜单,悬浮的都没用

三、小程序和H5之前的互相通讯

1、 从小程序 ==>> h5

小程序控制H5,可以直接用src路径传参的形式,比如

<!--  小程序端 HTML -->
<web-view  src="//URL?a=param1&b=param2"></web-view>

避免在链接中带有中文字符,在 iOS 中会有打开白屏的问题,建议加一下 encodeURIComponent。

2、 从 H5 ==>> 小程序

这里我们知道bindmessage是小程序用来监听H5的推送的内容,但是这里不大不小的坑!就是它的三个出发场景:

  • 小程序后退:使用接口名 wx.miniProgram.navigateTo,wx.miniProgram.navigateBack,wx.miniProgram.switchTab 等切换小程序页面/场景的API时候都会出发
  • 分享:这个就是当你点分享小程序的时候,会接受到H5之前发送的postMessage
  • 组件销毁,web-view组件销毁,类似 wx.miniProgram.redirectTo 都会触发。
<!--  小程序端 HTML -->
<web-view bindmessage="handleGetMessage"  src="{{openUrl}}"></web-view>
// 小程序端 JS -->
Page({
  /**
   * 页面的初始数据
   */
  data: {
    openUrl: "",
  },
  /**
   * 获取请求数据
   */
  handleGetMessage: function (e) {
    console.log(e.detail.data);
    }
  },
})
<!-- h5端 HTML和JS -->
<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.2.js"></script>
<script>
wx.miniProgram.postMessage({
    data: {
        link: "//test.com",
        title: "一起学习,一起进步"
    }
});
//wx.miniProgram.redirectTo({
//  url:"/pages/inner/index?source=123"
//})
wx.miniProgram.navigateBack({delta: 1})
</script>

注意事项

  1. 那些H5控制小程序的跳转路径必须是“/”开头,如 “/pages/xxx/xxx”,且路径必须在app.json里有,地址错误的话,有时不报错。
  2. postMessage的json必须是data开始,不然接收不到数据。

四、bindmessage接收到消息有3个重要特性(重点)

  1. 接收可以是H5之前几分钟前发送postMessage,不一定是即刻发出的。

  2. 之前发出的 postMessage的DATA信息会累加,当触发bindmessage接收的时候是一个数组。

  3. 当bindmessage 再次 接收到数据,之前发送的数据不会被清空,将累加一起返回,获取时要判断好数组的角标

五、Tips

1、在IDE工具中如何调试H5


可以在 web-view 组件上通过右键 - 调试,打开 web-view 组件的调试。

2、内嵌H5缓存问题

web-view加载的H5具有很重的缓存,如果需要调试,可以通过在url后面加时间戳的方式解决。

3、小程序关闭,H5背景音乐仍然在播放问题

小程序已经关闭,但是H5自带的背景音乐仍然在手机后台播放的问题。这里可以利用一个属性:

visibilitychange:页面可见性状态

简单的说,浏览器标签页被隐藏或显示的时候会触发visibilitychange事件。

var statusBeforeHide = true; //初始化页面的状态
var music = document.getElementById("xxx");
// 更改音乐播放状态
function setChangeMusic() {
    if (document[hiddenProperty]) {
        // 页面隐藏
        if (statusBeforeHide) {
            music.pause(); // 暂停
        }
    } else {
        // 页面显示
        if (statusBeforeHide) {
            music.play() //如果statusBeforeHide是true, 继续播放
        }
    }
}

let hiddenProperty = ('hidden' in document) ? 'hidden'
        : ('webkitHidden' in document) ? 'webkitHidden'
            : ('mozHidden' in document) ? 'mozHidden' : null;
if (hiddenProperty) {
    let visibilityChangeEvent = hiddenProperty.replace(/hidden/i, 'visibilitychange');
    let onVisibilityChange = () => {
        //console.log('visibilityChange');
        setChangeMusic();
    };
    document.addEventListener(visibilityChangeEvent, onVisibilityChange);
} else {
    console.log("不支持这个api");
}

总结,web-view还是非常实用的组件,且用且珍惜~

往期回顾:

最后一次编辑于  2021-09-13  
点赞 32
收藏
评论

35 个评论

  • 阿巴阿巴
    阿巴阿巴
    2020-07-06

    文章有错误吧,jssdk是同一个。不区分公众号还是小程序。

    2020-07-06
    赞同
    回复 2
    • 游戏人生
      游戏人生
      2020-07-06
      没表述清楚,是同一个jssdk,但是webview的功能收到限制,和之前微信打开H5有所不同
      2020-07-06
      回复
    • 阿巴阿巴
      阿巴阿巴
      2020-07-08回复游戏人生
      赞。理解一致,表述现在也一致了。我看到社区两个写webview的帖子都是同样一句话简述。虽然我们理解,但初学者可能会不好理解,特别对于没有做过公号网页开发者。
      2020-07-08
      回复
  • 🐮 發財💰
    🐮 發財💰
    2020-07-03

    想要问一下,web-view内嵌的页面,在点击小程序三个点分享的时候,别人打开的时候可以定位到H5的某个特定页面嘛?

    这个是我内嵌H5的页面的分享,我获取到当前H5里面页面的路径,带给了小程序,但是别人点击我的分享,打开时,路径还是首页,有什么办法解决吗?

    2020-07-03
    赞同
    回复 3
    • 游戏人生
      游戏人生
      2020-07-03
      看起来写法没错,我们先排查下,我怀疑你是分享的路径后面的重定向不对,webViewUrl 这个要是个干净的url且最好是域名地址,不要是IP!!!绑个host?因为IP的妖怪问题很多,比如分享到A页面,就写https://a.com,我自己这样写一直都是正常的,如果跳转到首页,说明你分享的路径有问题,另外为什么这个console的openUrl是重复的
      2020-07-03
      2
      回复
    • 🐮 發財💰
      🐮 發財💰
      2020-07-03回复游戏人生
      谢谢,问题已经解决啦,的确是url的妖怪问题,是我原本的H5路径是hash模式,就带有#,微信把#后面的路径都屏蔽啦,所以才出现了这个问题,后面改成history模式就好啦,谢谢啦
      2020-07-03
      回复
    • 游戏人生
      游戏人生
      2020-07-03回复🐮 發財💰
      嗯嗯,解决了就好,不客气
      2020-07-03
      回复
  • 关耳白告予
    关耳白告予
    2020-06-10

    感觉有点云。你实际试过wx.miniProgram.navigateTo吗?并不能给小程序发送数据

    2020-06-10
    赞同
    回复 3
    • 游戏人生
      游戏人生
      2020-06-12
      可以的,离开当前页面A就会触发A中的JS,只是很多人没有把方法写成全局,然后跳转到页面B后发现没有接受到,以为不行,一开始我也犯过类似的错
      2020-06-12
      回复
    • 关耳白告予
      关耳白告予
      2020-06-17回复游戏人生
      bindmessage肯定是就组件在的那一个页面吧。
      所以我理解的你说的是bindmessage="bindmessageFunc",要把bindmessageFunc写成全局方法?这个我真没试过。
      而且官方文档说的是组件销毁和小程序后退。万一这个能接收到,当时候被官方当bug改掉咋办
      2020-06-17
      回复
    • passion to live
      passion to live
      2020-11-12回复关耳白告予
      使用当前页面的方法也可以,前提是要用wx.miniProgram.redirectTo,这样才会触发组件销毁并收到消息,亲测有效。
      2020-11-12
      回复
  • JIang
    JIang
    2020-05-13

    息屏测试过了么,我这边安卓息屏不触发,visibilitychange,但是进入后台就触发,ios 进入后台和息屏都没问题,我快哭了

    2020-05-13
    赞同
    回复 6
    • 游戏人生
      游戏人生
      2020-05-14
      这里有写呀,Android的机器类型和微信版本都有关系,你试着更新到最新看下,我们之前也有类似的问题,但是用这个方法,测试了下主流的机型(覆盖率大概70%+)是可以用的
      2020-05-14
      回复
    • JIang
      JIang
      2020-05-14回复游戏人生
      我这边华为的都不行,牛逼的是我们同事都用华为没有其他安卓的机子
      2020-05-14
      回复
    • JIang
      JIang
      2020-05-14回复游戏人生
      statusBeforeHide 你写的这个我没看懂
      2020-05-14
      回复
    • 游戏人生
      游戏人生
      2020-05-14回复JIang
      记录页面切换到后台时音乐的播放状态,如果用户主动关闭,就会设置成false,则不再处罚,我只贴了一部分代码,外部还有有个设置false的功能,就是用户主动关闭的。华为,我们之前测是出发的。。。如果实在有问题,建议你提个BUG,把代码段和机器详情贴出来,让官方看下
      2020-05-14
      回复
    • JIang
      JIang
      2020-05-14回复游戏人生
      提过了,这两天就在处理这个问题,你的这部分代码我刚测试完,依旧还是华为锁屏不触发,坑呀
      2020-05-14
      回复
    查看更多(1)
  • 林  晓
    林 晓
    2020-04-08

    你好,请问下在微信小程序内嵌入一个html5网页页面,怎么设置微信小程序的后台管理呢,我直接卡在这里,

    因为小程序项目的后台是在tomcat中运行的,带有端口,检验文件发在tomcat的root文件下,一直都有端口,要什么办法才能通过这个域名的验证

    2020-04-08
    赞同
    回复 1
    • 游戏人生
      游戏人生
      2020-04-08
      首先必须是业务域名,你要在你的域名跟目录下添加校验文件,比如你的域名是  abc.com,那么你把校验文件添加在根目录后,abc.com/xxxx.txt 校验文件必须得可以访问,添加好后,就只可以直接引用了
      2020-04-08
      回复

正在加载...

登录 后发表内容