我的编程空间,编程开发者的网络收藏夹
学习永远不晚

web网页与小程序间如何进行通信

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

web网页与小程序间如何进行通信

本篇内容介绍了“web网页与小程序间如何进行通信”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

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

小程序提供的功能

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

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

网页

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

小程序

index.wxml

通过bindmessage绑定接收事件

<web-view bindmessage='getMessage' class="lazy" data-src='{{ class="lazy" data-src }}'></web-view>

index.js

// 获取从网页发送来的消息getMessage(e) {  const getMessage (e) {  // data是多次postMessage的参数组成的数组  const { data } = e.detail;  // 需要取最后一条数据  let shareMessage = data[data.length - 1];  this.shareMessage = JSON.parse(shareMessage);};// 设置分享onShareAppMessage(options) {  return {    title: this.shareMessage.title,    path:  this.shareMessage.path,    imageUrl: this.shareMessage.imageUrl,  };}

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

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

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

1、场景还原

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

web网页与小程序间如何进行通信

选择城市之后会在首页右上角展示

web网页与小程序间如何进行通信

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

2、解决方案

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

网页

// 保存城市信息const saveCityHandle = () => {  saveCity({    cityId: cityId,    userId: userId,  }).then(() => {});};

小程序

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

wx.login({  success(res) {    if (res.code) {      wx.request({        url: `${that.domain()}/getUserInfo`,        data: {          body: { jsCode: res.code },        },        success(res) {          wx.setStorageSync('cityId', res.data.cityId);        },      });    } else {      console.log('登录失败!' + res.errMsg);    }  },});

总结

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

有时候回过头来看看某些知识点,也许就会有新的思路,与君共勉。ヾ(◍°∇°◍)ノ゙

一首小诗

看了一眼日期,发现12月,2021年最后一个月了,我之前写过了一首小诗,有点符合我现在的心境,也有一些祝福送给自己也送给大家。

眼前是一扇窗,窗外是变换的景色,夜晚,墨绿的树,散落灯光的高楼大厦,疾驰的汽车,或匆忙或悠闲的行人。我好像记住了每一座楼宇,却不记得每一张面孔,不变的建筑,变换的路人。今年,有一些变化,每一颗追求人生的心,都值得期待,每一个不舍的眼神,笑容也无法遮掩。致,所有开发的伙伴,一期一祈,勿怀犹也,幸福美好。

“web网页与小程序间如何进行通信”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

web网页与小程序间如何进行通信

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

web网页与小程序间如何进行通信

本篇内容介绍了“web网页与小程序间如何进行通信”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!我们的微信小程序采用的web-view的方式内
2023-06-21

如何进行微信小程序的页面跳转

本篇文章为大家展示了如何进行微信小程序的页面跳转,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。我们将创建第二个视图,然后实现从第一个视图到第二个视图的跳转。首先开发第二个视图:微信小程序开发系列七:
2023-06-05

Android进程间如何使用Intent进行通信

这篇文章主要介绍“Android进程间如何使用Intent进行通信”,在日常操作中,相信很多人在Android进程间如何使用Intent进行通信问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Android进程
2023-07-05

如何使用Java进行网络通信编程?(在Java中,应如何编写网络通信程序?)

Java提供强大的网络通信功能,可用于编写健壮的网络应用程序。通过使用TCP/IP套接字,您可以创建客户端端和服务器端程序,并通过数据流进行通信。数据序列化允许传输复杂对象,而高级功能(如多线程和NIO)可提高性能并简化编程。本指南详细介绍了如何在Java中进行网络通信编程,包括服务器端和客户端端示例,以及高级功能的概述。
如何使用Java进行网络通信编程?(在Java中,应如何编写网络通信程序?)
2024-04-02

微信小程序如何实现页面间传值

这篇文章主要介绍“微信小程序如何实现页面间传值”,在日常操作中,相信很多人在微信小程序如何实现页面间传值问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”微信小程序如何实现页面间传值”的疑惑有所帮助!接下来,请跟
2023-06-14

微信小程序如何配置页面与路由

这篇文章将为大家详细讲解有关微信小程序如何配置页面与路由,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、小程序配置1、全局配置小程序根目录下的 app.json 文件用来对微信小程序进行全局配置,决定页
2023-06-20

如何进行小程序的测试与调试

小程序的测试与调试可以通过以下几个步骤来进行:使用开发者工具:小程序开发者工具是一个专门用于小程序开发和调试的工具,可以在其中模拟不同的机型和系统环境,实时查看小程序的效果和调试代码。使用真机调试:在开发者工具中可以连接真机进行调试,以查看
如何进行小程序的测试与调试
2024-04-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录