浅析网页与小程序间怎么进行通信

 2968

网页与小程序间怎么进行通信?下面本篇文章给大家介绍一下关于网页与小程序通信的相关知识,希望对大家有所帮助!


浅析网页与小程序间怎么进行通信


我们的微信小程序采用的web-view的方式内嵌H5项目,从而减少开发量,在实际只用中会遇到网页与小程序通信的功能需要,下面我简单总结了我遇到的问题以及解决方案。

小程序提供的功能

微信提供了网页向小程序发送消息的方法:wx.miniProgram.postMessage,该方法向小程序发送消息,会在特定时机(小程序后退、组件销毁、分享)触发组件的message事件。

具体API详情可以查看 微信开放文档

https://developers.weixin.qq.com/miniprogram/dev/component/web-view.html

简单介绍一下如果使用,以分享为例,如果页面A需要特别设置分享内容,比如转发标题、缩略图等。可以再网页中设置好变量值,通过发送给小程序


网页

  1. let shareData = {
  2.   path: '转发路径',
  3.   title: '自定义转发标题',
  4.   imageUrl: '缩略图url',
  5. };
  6. wx.miniProgram.postMessage({ data: JSON.stringify(shareData) });


小程序

index.wxml

通过bindmessage绑定接收事件

  1. <web-view bindmessage='getMessage' src='{{ src }}'></web-view>

index.js

  1. // 获取从网页发送来的消息
  2. getMessage(e) {
  3.   const getMessage (e) {
  4.   // data是多次postMessage的参数组成的数组
  5.   const { data } = e.detail;
  6.   // 需要取最后一条数据
  7.   let shareMessage = data[data.length - 1];
  8.   this.shareMessage = JSON.parse(shareMessage);
  9. };
  10.  
  11. // 设置分享
  12. onShareAppMessage(options) {
  13.   return {
  14.     title: this.shareMessage.title,
  15.     path:  this.shareMessage.path,
  16.     imageUrl: this.shareMessage.imageUrl,
  17.   };
  18. }

这样一次定制化分享功能就完成了,但是postMessage方法只有特定场景可以获取消息,所以如果非特定场景怎么获取通信呢?


一种简单的获取通信的方法

我提供的解决方案可能不是最优的也不是最通用的,但是如果遇到了问题时可以作为一个备选方案。

1、场景还原

我们的小程序中有城市定位,第一次进入小程序需要选择所在城市,选择城市之后会缓存到本地,之后再次进入小程序不再需要重选选择城市。功能如下截图


浅析网页与小程序间怎么进行通信

浅析网页与小程序间怎么进行通信


由于城市选择页面和首页都是通过web-view内嵌小程序的方式,所以显然在H5页面中进入缓存,在小程序中是无法获取到缓存信息的。


2、解决方案

解决方案很简单,我跟后端的同伴沟通后,拜托他提供给我一个接口,把城市id和用户信息关联起来,这样我就可以再用户进行小程序的时候获取用户上次选择的城市id,进而再小程序里面缓存处理,这样用户再次进入小程序的时候无需再次选择城市

网页

  1. // 保存城市信息
  2. const saveCityHandle = () => {
  3.   saveCity({
  4.     cityId: cityId,
  5.     userId: userId,
  6.   }).then(() => {});
  7. };

小程序

获取城市id之后通过wx.setStorageSync缓存下来,以便后续使用。

  1. wx.login({
  2.   success(res) {
  3.     if (res.code) {
  4.       wx.request({
  5.         url: `${that.domain()}/getUserInfo`,
  6.         data: {
  7.           body: { jsCode: res.code },
  8.         },
  9.         success(res) {
  10.           wx.setStorageSync('cityId', res.data.cityId);
  11.         },
  12.       });
  13.     } else {
  14.       console.log('登录失败!' + res.errMsg);
  15.     }
  16.   },
  17. });

总结

“温故而知新,可以为师矣。”

有时候回过头来看看某些知识点,也许就会有新的思路,与君共勉。



TAG标签:
本文网址:https://www.zztuku.com/index.php/detail-10357.html
站长图库 - 浅析网页与小程序间怎么进行通信
申明:本文转载于《掘金社区》,如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐