云裂变营销网

标题: 微信小程序web-view与H5 通信方式探索 [打印本页]

作者: 匿名    时间: 2022-12-8 10:24
标题: 微信小程序web-view与H5 通信方式探索
本文作者为奇舞团前端开发工程师 蔡宁
小程序简介

小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验。
需求

微信小程序 H5 混合开发就是 在一个小程序中,采用部分小程序原生页面,部分通过Webview内嵌 H5 页面,二者配合实现完整业务逻辑的方案。

微信小程序web-view与H5 通信方式探索-1.jpg

image.png

为什么需要混合开发

小程序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

微信小程序web-view与H5 通信方式探索-2.jpg

image.png

微信小程序web-view与H5 通信方式探索-3.jpg

image.png


微信小程序web-view与H5 通信方式探索-4.jpg

image.png



微信小程序web-view与H5 通信方式探索-5.jpg

image.png

Bug & Tip



微信小程序web-view与H5 通信方式探索-6.png

image.png

小程序与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: {} } });


微信小程序web-view与H5 通信方式探索-7.jpg

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')


微信小程序web-view与H5 通信方式探索-8.jpg

image.png

长连-Websocket

优点:可以实现实时通信
缺点:成本高,服务器压力大等;放弃此方式。
总结

优化-骨架屏



微信小程序web-view与H5 通信方式探索-9.jpg

entrance.d6f1d566.png

骨架屏是页面的一个空白版本,通常会在页面完全渲染之前,通过一些灰色的区块大致勾勒出轮廓,待数据加载完成后,再替换成真实的内容。骨架屏在内容还没有出现之前的页面骨架填充,以免留白。
小程序骨架屏引入方式

使用方法:
<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>
.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;
}<import src="index.skeleton.wxml"/>
<template is="skeleton" wx:if="{{loading}}" />
@import "./index.skeleton.wxss";
小程序骨架屏官方指引
H5骨架屏引入方式

Page Skeleton是一款 webpack 插件,该插件的目的是根据你项目中不同的路由页面生成相应的骨架屏页面,并将骨架屏页面通过 webpack 打包到对应的静态路由页面中。
H5 骨架屏使用方式具体见Page Skeleton GitHub
引用


作者: DirkHo    时间: 2022-12-8 10:25
小程序用户的留存率太低




欢迎光临 云裂变营销网 (https://www.yunliebian.com/yingxiao/) Powered by Discuz! X3.4