微信小程序webview通信

本文在uniapp 框架背景下生成,其他情况仅作参考

开始

直接照着文档来即可。

小程序页面:

scss 复制代码
message(e) {
    console.log(e.detail.data)
}
<web-view src="xxx" @message="message"></web-view>

h5页面:

css 复制代码
uni.postMessage({
    data: {
        action: 'message'
    }
});

实际上在h5页面postMessage 之后发现并没有触发小程序页面的message 事件,仔细看文档发现只有在特定的时机才会触发:后退组件销毁分享

可以在h5页面多次postMessage ,最终message 事件的参数会是个按顺序生成的数组。

H5页面

进行在小程序上不易处理的逻辑操作,本文的案例是根据DOM 生成图片,采用的是html2canvas 库。

完成之后或返回,或跳转其他页面,都需要调用小程序的API,这里通过weixin-webview-jssdk 实现。

通信

分享

通过页面的分享按钮触发,此时仍在当前页面,直接处理相关逻辑即可。

后退

这个后退 是指包含webview 标签的这个小程序页面的后退。那么这里需要一个中间页面,在onShow时判断是要跳转到该小程序页面,还是展示数据。此时整个流程就非常清晰了,具体的细节稍微画了一下流程图来展示。

如果是h5环境,则直接展示h5页面。

如果是微信环境,跳转到中间页面,在onLoad 中立即跳转到小程序页面。

小程序页面中由webview 标签嵌套h5页面,在h5页面中获取数据之后,自动执行小程序的返回操作,此时又会回到中间页面。 同时触发webview 标签的message事件,然后将数据发送给中间页面。具体的页面通信方式在下文作详细阐述。

返回到中间页面,检测到有数据存在,则不会自动跳转到小程序页面,而是展示数据。

如果直接在小程序页面返回(不是在h5中获取数据之后调用的返回),则回到中间页面时不会有数据,则再次执行返回,回到初始页。

销毁

这个销毁 是指包含webview 标签的销毁。那么仍然需要一个中间页面,在数据生成之后,通过页面间通信的方式来通知小程序页面销毁webview 标签,具体的细节稍微画了一下流程图来展示。

如果是h5环境,则直接展示h5页面。

如果是微信环境,跳转到小程序页面。维护一个控制webview标签展示的flag,默认为true。

sql 复制代码
<web-view v-if="flag" src="xxx" @message="message"></web-view>

此时展示h5页面,生成数据之后跳转到中间页,中间页通知小程序页面数据生成了(具体的页面通信方式在下文作详细阐述.),该把flag 置为false了,然后执行返回操作。

回到小程序页面,发现flag 为false且存在数据,则webview 组件销毁,触发message 事件,执行数据处理逻辑。

页面间通信

  1. 通过getCurrentPages 方法可以获取到页面栈,找到对应的页面实例,就可以修改其中的数据。

  2. uni.$emit + uni.$on 实现的页面间通信

    发送页面:

    bash 复制代码
    uni.$emit("fn", { payload: "anything" })

    接收页面:

    javascript 复制代码
    uni.$on("fn",(res) => {
        console.log(res)
    })

    记得取消监听

    javascript 复制代码
    onUnload() {
      uni.$off("fn")
    },
  3. 与上个方法类似,由微信提供的API。

    发送页面:

    kotlin 复制代码
    this.eventChannel = this.getOpenerEventChannel()
    this.eventChannel.emit('fn', { payload: "anything" });

    接收页面:

    css 复制代码
    uni.navigateTo({
        url: 'xxx',
        events: {
            fn: data => fn()
        }
    })
相关推荐
knight_l1 分钟前
【附源码,附两款可视化大屏】Three.js中的地图精确贴图与热力图实现解析
前端
华洛1 分钟前
《回顾我的AI学习之路,上万字的AI学习思维导图分享》
前端·后端·产品经理
PBitW2 分钟前
工作两年,从自己造轮子,变成使用开源项目!
前端·开源·若依·为什么使用开源项目·不自己造轮子
cindershade3 分钟前
Vue3 实时音频录制与转写 Composable 技术实现
前端
张风捷特烈10 分钟前
Flutter&TolyUI#12 | 树形组件 toly_tree 重磅推出!
android·前端·flutter
柯南二号14 分钟前
【大前端】【Android】一文详解Android MVVM 模式详情解析
android·前端
Mintopia17 分钟前
⚛️ 深入学习 React Fiber 架构的思路分析
前端·react.js·架构
页面魔术23 分钟前
⭐看完vite纪录片才知道尤大有多屌(上)
前端·javascript·vue.js
UpgradeLink33 分钟前
Electron 项目使用官方组件 electron-builder 进行跨架构打包
前端·javascript·electron
蚂蚁不吃土&43 分钟前
cmd powershell svm nodejs npm
前端·npm·node.js