小程序webView 实现小程序内嵌H5页面
创始人
2024-12-27 11:41:43
0

web-view | 微信开放文档

本案例新建了一个 webView页面  只渲染webView组件

配置路由,跳转页面的时候 前缀使用‘/subPages/webView/index?weburl=https://xxxxx’

componentDidMount 的时候 获取路由中的 weburl 地址参数

  async componentDidMount() {     const router = getCurrentInstance().router;     const params = router.params;         let url = params.weburl;     // 对url进行参数处理 ,可以增加需要传递给H5的token等其他参数      this.setState({       url: url, // 获取其他小程序页面 请求跳转的地址     });   }       render() {     const { url } = this.state;      return (      {           this.setPostMessage(res.detail.data); // 存储H5传回来的数据 可以存到公共区域 方便使用         }}       />     );   }  

发起跳转的方式:

const token=''; // 自行获取token const weburl='' ;// 自行定义地址 Taro.navigateTo({     url: `/subPages/webView/index?weburl=${weburl}&token=${token}` , }); 

上面是跳转到小程序的webview.jsx页面  并且带上了需要跳转的H5地址weburl

在webview页面加载的时候获取H5地址 并添加在web-view标签上 

如果页面中很多地方需要跳转H5页面 并且H5页面是基本固定的域名 可以将Taro.navigateTo进行封装处理

案例:

const toWebFun = (type = 'navigateTo') => {   return function (url, isRequireToken) {     const params = queryToObj(url); //      const token = Taro.getStorageSync(ConstantList.TOKEN); //      const host = Config.HOST_H5; // H5固定域名     const TaroNavigate = type === 'redirectTo' ? Taro.redirectTo : Taro.navigateTo;     let path = '';     let tokenKey = '?token=';     let ismini = '?ismini=1'; // 个人定义代表小程序内打开H5 方便区分      // 带有https链接情况 就不使用host固定域名     if (url.includes('https://')) {       path = `/subPages/webView/index?weburl=${encodeURIComponent(         `${url}${url.indexOf('?') > -1 ? '&token=' : '?token='}${token}&ismini=1`,       )}`;       TaroNavigate({         url: path,       });       return;     }     // 如果连接本身带有?后面参数 则不要覆盖 而是追加      if (url.indexOf('?') !== -1) {       tokenKey = '&token=';       ismini = '&ismini=1';     }     if (isRequireToken) { // 是否需要登录的页面       if (token) {         path = `/subPages/webView/index?weburl=${encodeURIComponent(`${host}#${url + tokenKey + token}${ismini}`)} `;       } else { // 需要登录 有没有token的情况 先跳转登录 然后 带上url登陆后继续执行跳转操作 又会继续执行toWebFun 函数         Taro.navigateTo({           url: `/subPages/login/index?redirectTo=${url}`,         });         return;       }     } else { // 无需token       path = `/subPages/webView/index?weburl=${encodeURIComponent(`${host}#${url}${ismini}`)}`;     }     TaroNavigate({       url: path,     });   }; };  export const navigateToWeb = toWebFun(); 

在其他页面就是使用navigateToWeb 跳转H5页面

H5页面中提供一下方法回到小程序页面及给小程序页面传值

小程序和网页之间的通信是单向的,即只能从网页发送消息到小程序,不能从小程序发送消息到网页。

// H5与小程序交互的方式  // 返回小程序首页 wx.miniProgram.navigateTo({url: '/pages/home/index'})  // 给小程序传递参数 wx.miniProgram.postMessage({ data: 'foo' }) // 给小程序传递复杂参数 wx.miniProgram.postMessage({ data: {foo: 'bar'} })   // 小程序web-view 存储H5传回来的数据 // onMessage={(res) => { //    this.setPostMessage(res.detail.data); // 存储H5传回来的数据 // }}  // 获取当前环境 wx.miniProgram.getEnv(function(res) { console.log(res.miniprogram) })     // 小程序下的H5 去小程序的虚拟订单页 wx.miniProgram.navigateTo({url:`/subPages/virtualOrderList/virtualOrderList?type=coupon`});   

小程序可以在跳转之前在url携带一些参数,

或者直接通过后端缓存的方式 在小程序存储缓存换取缓存id,拼接在url上,跳转到H5之后通过缓存id获取缓存数据

相关内容

热门资讯

揭幕了解!微乐家乡官方app(... 您好,微乐家乡官方app这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多...
科普了解!红黑大战控制系统(辅... 科普了解!红黑大战控制系统(辅助)桔子派对一贯真的是有辅助app(哔哩哔哩)1、许多玩家不知道红黑大...
详情了解!小程序微乐贵阳捉鸡麻... 详情了解!小程序微乐贵阳捉鸡麻将挂(辅助)欢乐吓牌原来是有辅助脚本(哔哩哔哩)1、打开软件启动之后找...
专业了解!蜀山挂件辅助(辅助)... 专业了解!蜀山挂件辅助(辅助)同城游合肥麻将原来有挂辅助下载(哔哩哔哩)专业了解!蜀山挂件辅助(辅助...
专业了解!新玉海楼茶苑辅助器(... 专业了解!新玉海楼茶苑辅助器(辅助)旋转光线一直有挂辅助器(哔哩哔哩)1、不需要AI权限,帮助你快速...
解迷了解!兴动互娱辅助脚本io... 解迷了解!兴动互娱辅助脚本ios下载(辅助)王者陕西麻将切实真的有辅助安装(哔哩哔哩)在进入兴动互娱...
教你了解!圣盛鄂州晃晃辅助(辅... 教你了解!圣盛鄂州晃晃辅助(辅助)新棋联盟一直真的有辅助挂(哔哩哔哩)1)圣盛鄂州晃晃辅助辅助插件:...
揭幕了解!哈糖大菠萝辅助器(辅... 揭幕了解!哈糖大菠萝辅助器(辅助)中至汾阳麻将一直有挂辅助挂(哔哩哔哩)1、下载好哈糖大菠萝辅助器透...
揭露了解!广丰510k同城游攻... 揭露了解!广丰510k同城游攻略(辅助)九九茶楼真是是有辅助软件(哔哩哔哩)进入游戏-大厅左侧-新手...
专业了解!传送屋高仿版辅助(辅... 专业了解!传送屋高仿版辅助(辅助)凤娱好像是有辅助软件(哔哩哔哩)1、传送屋高仿版辅助脚本辅助下载、...