微信小程序web-view与H5 通信方式探索
Posted 奇舞周刊
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了微信小程序web-view与H5 通信方式探索相关的知识,希望对你有一定的参考价值。
本文作者为奇舞团前端开发工程师
小程序简介
小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验。
需求
微信小程序 H5 混合开发就是 在一个小程序中,采用部分小程序原生页面,部分通过Webview内嵌 H5 页面¹,二者配合实现完整业务逻辑的方案。
为什么需要混合开发
小程序WebView基本用法
用法
<web-view class="web-holder" src="url" bindload="bindload" binderror="binderror" bindmessage="bindGetMsg"></web-view>
web-view网页中可使用JSSDK 1.3.2提供的接口返回小程序页面。支持的接口有:
接口名 | 说明 | 最低版本 |
---|
wx.miniProgram.navigateTo | 参数与小程序接口一致 | 1.6.4 |
wx.miniProgram.navigateBack | 参数与小程序接口一致 | 1.6.4 |
wx.miniProgram.switchTab | 参数与小程序接口一致 | 1.6.5 |
wx.miniProgram.reLaunch | 参数与小程序接口一致 | 1.6.5 |
wx.miniProgram.redirectTo | 参数与小程序接口一致 | 1.6.5 |
wx.miniProgram.postMessage | 向小程序发送消息,会在特定时机(小程序后退、组件销毁、分享)触发组件的 message 事件 | 1.7.1 |
wx.miniProgram.getEnv | 获取当前环境 | 1.7.1 |
image.png
Bug & Tip
tip:网页内 iframe 的域名也需要配置到域名白名单。
tip:开发者工具上,可以在 web-view 组件上通过右键 - 调试,打开 web-view 组件的调试。
image.png
tip:每个页面只能有一个 web-view,web-view 会自动铺满整个页面,并覆盖其他组件。
tip:web-view 网页与小程序之间不支持除 JSSDK 提供的接口之外的通信。
tip:在 ios 中,若存在 JSSDK 接口调用无响应的情况,可在 web-view 的 src 后面加个#wechat_redirect解决。
tip:避免在链接中带有中文字符,在 iOS 中会有打开白屏的问题,建议加一下 encodeURIComponent
小程序与H5 通信方式
方式一:小程序->H5 通过 URL 拼接参数
http://127.0.0.1:8080/test?key=123
方式二:H5->小程序wx.miniProgram.postMessage
api
实现方式:
<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script>
npm install weixin-webview-jssdk
<web-view bindmessage="bindGetMsg"></web-view>
bindGetMsg:function(res)
console.log('从h5页面获取到的信息----->',res)
import wx from "weixin-webview-jssdk";
wx.miniProgram.postMessage( data: foo: );
image.png
优点:接入成本低
缺点:向小程序发送消息,会在特定时机(小程序后退、组件销毁、分享)触发组件的 message 事件,只能这些特定时机,基本宣布postMessage没用!因为这些时机很苛刻,不符合我们要求。反人类设计!
方式二:url 携带信息navigateTo
、reLaunch
、redirectTo
实现方式:
wx.miniProgram.navigateTo(
url: '../h5/loading-page',
)
wx.miniProgram.navigateTo(
url: '../h5/loading-page?type=aaa',
)
缺点:url 数据量有限,且需要打开界面
方式三:内存共享
无法实现,原因 wx.setStorage 与localStorage 隔离
localStorage.setItem('h5key','value')
wx.setStorageSync('wx-key', 'value')
image.png
长连-Websocket
Websocket 简介:WebSocket 是 html5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议;
建立在 TCP 协议之上,服务器端的实现比较容易。
与 HTTP 协议有着良好的兼容性。默认端口也是80和443,并且握手阶段采用 HTTP 协议,因此握手时不容易屏蔽,能通过各种 HTTP 代理服务器。
数据格式比较轻量,性能开销小,通信高效。
可以发送文本,也可以发送二进制数据。
没有同源限制,客户端可以与任意服务器通信。
协议标识符是ws(如果加密,则为wss),服务器网址就是 URL。
优点:可以实现实时通信
缺点:成本高,服务器压力大等;放弃此方式。
总结
微信并不鼓励在小程序中大范围嵌入 H5,为了避免开发者把小程序变成“浏览器”,微信对小程序与内嵌 H5 的通讯做了诸多限制
尽量使用单一方式实现,比如纯小程序原生,将h5功能移至小程序原生
原生页面与 H5 之间通过 URL 进行通信
不要尝试越过wx 限制
不得不用混合开发时,尽量做好优化,引入骨架屏等优化方式提高用户体验感
以上三种方式均未很好实现web-view 与H5双向通信
优化-骨架屏
骨架屏是页面的一个空白版本,通常会在页面完全渲染之前,通过一些灰色的区块大致勾勒出轮廓,待数据加载完成后,再替换成真实的内容。骨架屏在内容还没有出现之前的页面骨架填充,以免留白。
小程序骨架屏引入方式
使用方法:
生成骨架屏页面index.skeleton.wxml
<template name="skeleton">
<view class="sk-container">
<view class="container">
<view class="userinfo">
<view class="userinfo-avatar">
<open-data type="userAvatarUrl"></open-data>
</view>
<open-data type="userNickName"></open-data>
</view>
<view class="usermotto">
<text class="user-motto sk-transparent sk-text-14-2857-765 sk-text">Hello World</text>
</view>
</view>
</view>
</template>
生成骨架屏样式index.skeleton.wxss
.sk-transparent
color: transparent !important;
.sk-text-14-2857-765
background-image: linear-gradient(transparent 14.2857%, #EEEEEE 0%, #EEEEEE 85.7143%, transparent 0%) !important;
background-size: 100% 44.8000rpx;
position: relative !important;
.sk-text
background-origin: content-box !important;
background-clip: content-box !important;
background-color: transparent !important;
color: transparent !important;
background-repeat: repeat-y !important;
.sk-container
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
overflow: hidden;
background-color: transparent;
在 /pages/index/index.wxml
引入模板
<import src="index.skeleton.wxml"/>
<template is="skeleton" wx:if="loading" />
在 /pages/index/index.wxss
中引入样式
@import "./index.skeleton.wxss";
小程序骨架屏官方指引
H5骨架屏引入方式
Page Skeleton是一款 webpack 插件,该插件的目的是根据你项目中不同的路由页面生成相应的骨架屏页面,并将骨架屏页面通过 webpack 打包到对应的静态路由页面中。
H5 骨架屏使用方式具体见Page Skeleton GitHub
引用
- END -
关于奇舞团
奇舞团是 360 集团最大的大前端团队,代表集团参与 W3C 和 ECMA 会员(TC39)工作。奇舞团非常重视人才培养,有工程师、讲师、翻译官、业务接口人、团队 Leader 等多种发展方向供员工选择,并辅以提供相应的技术力、专业力、通用力、领导力等培训课程。奇舞团以开放和求贤的心态欢迎各种优秀人才关注和加入奇舞团。
微信小程序中的 web-view 组件
web-view 是一个可以承载 web 网页的容器,当 WXML 文件中存在 web-view 组件时,其他组件会自动全部失效,而且 web-view 承载的组件会自动铺满小程序的整个页面。其他组件的内容将不再显示。
使用方法:
<web-view src="https://baidu.com"></web-view>
注意事项:
1. src 属性的值是一个网页链接,且该链接必须在小程序管理后台中的域名白名单中。
2. 用户在分享是可以获取当前页面 <web-view> 的 src 的值,在页面的 onShareAppMessage 事件中可以获取到该值。
即:onShareAppMessage:function( options ){
console.log( options.webVIewUrl );
// 可进行下一步操作
}
其他功能(主要是 JSSDK 1.3.0 提供的功能):
1. 功能描述:
在 web-view 内嵌的网页中可以使用 JSSDK 1.3.0 提供的接口返回小程序页面。前提是必须在网页中引入 js 文件。
使用方法:
1. 页面中引入 js 文件:<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.0.js"></script>
2. 使用提供的接口返回小程序页面:
wx.miniProgram.navigateTo,参数与用法和小程序中的 wx.navigateTo 用法一致。
wx.miniProgram.navigateBack,参数与用法和小程序中的 wx.navigateBack 用法一致。
wx.miniProgram.switchTab,参数与用法和小程序中的 wx.switchTab 用法一致。
wx.miniProgram.reLaunch,参数与用法和小程序中的 wx.reLaunch 用法一致。
wx.miniProgram.redirectTo,参数与用法和小程序中的 wx.redirectTo 用法一致。
示例: wx.miniProgram.navigateTo({
url: "pages/personal/personal"
})
2. 功能描述:
在 web-view 内嵌的网页中可以使用 JSSDK 1.3.0 提供的方法判断当前页面是否存在于小程序环境中。
使用方法:
wx.ready(function() {
// console.log(window.__wxjs_environment === ‘miniprogram‘)
window.__wxjs_environment === ‘miniprogram‘
以上是关于微信小程序web-view与H5 通信方式探索的主要内容,如果未能解决你的问题,请参考以下文章
微信小程序web-view , 嵌入H5页面
前端探索微信小程序跳转的探索——开放标签为什么存在?
小程序与H5如何互相跳转
微信小程序封装H5使用web-view源码
小程序和H5页面的相互跳转
微信小程序web-view嵌入H5页面, H5页面向小程序页面传值