位置: IT常识 - 正文

如何Uniapp中嵌入H5,并且在H5中跳转到APP的指定页面(uniapp 嵌套webview)

编辑:rootadmin
如何Uniapp中嵌入H5,并且在H5中跳转到APP的指定页面 如何Uniapp中嵌入H5,并且在H5中跳转到APP的指定页面场景Web-View在官网中提供的是APP嵌入原生的H5页面在APP中使用web-view嵌入H5页面使用web-view组件就可以实现,代码如下调用方法跳转至app 的页面的关键方法 uni.reLaunch以上代码可以解决APP嵌入原生H5页面跳转回APP的问题,但是使用uniapp开发H5就会失效,在uniapp开发H5页面使用 uni.reLaunch 只能跳转到H5项目本地的页面。解决方法如下1. 下载官网web-view的SDK2. 在H5项目的main.js 文件里导入这个文件3. 原生H5使用的跳转方法和uniapp开发的H5使用的跳转方法是不一样的场景

推荐整理分享如何Uniapp中嵌入H5,并且在H5中跳转到APP的指定页面(uniapp 嵌套webview),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:uniapp嵌套页面,uniapp怎么用,uniapp引入element,uniapp 嵌套webview,uniapp嵌套页面,uniapp怎么引入elementui,uniapp嵌套页面,uniapp嵌入网页,内容如对您有帮助,希望把文章链接给更多的朋友!

有一个需求是,在app中嵌入一个H5页面,H5是一个网络页面,不在app项目里,APP可以打开H5页面,实现单点登录,并且在H5 页面中打开APP指定的页面

Web-View

在uniapp中,有一个web-view组件,这就相当于一个浏览器组件,可以用来承载网页的容器,会自动铺满整个页面 web-view的详细文档参考uniapp官网

https://uniapp.dcloud.net.cn/component/web-view.html#web-view在官网中提供的是APP嵌入原生的H5页面从官方demo的代码,原生H5页面使用的HTML在APP中使用web-view嵌入H5页面使用web-view组件就可以实现,代码如下<template><view><web-view src="https://uniapp.dcloud.io/static/web-view.html"></web-view></view></template>

src是H5的地址,可以是任何网址,与APP的地址什么的没有关系,也可以是www.baidu.com ,在这里为了方便测试,使用官方的 H5地址 官方原生h5 代码如下

<!DOCTYPE html><html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> <title>网络网页</title> <style type="text/css"> .btn { display: block; margin: 20px auto; padding: 5px; background-color: #007aff; border: 0; color: #ffffff; height: 40px; width: 200px; } .btn-red { background-color: #dd524d; } .btn-yellow { background-color: #f0ad4e; } .desc { padding: 10px; color: #999999; } .post-message-section { visibility: hidden; } </style> </head> <body> <p class="desc">web-view 组件加载网络 html 示例。点击下列按钮,跳转至其它页面。</p> <div class="btn-list"> <button class="btn" type="button" data-action="navigateTo">navigateTo</button> <button class="btn" type="button" data-action="redirectTo">redirectTo</button> <button class="btn" type="button" data-action="navigateBack">navigateBack</button> <button class="btn" type="button" data-action="reLaunch">reLaunch</button> <button class="btn" type="button" data-action="switchTab">switchTab</button> </div> <div class="post-message-section"> <p class="desc">网页向应用发送消息,注意:小程序端应用会在此页面后退时接收到消息。</p> <div class="btn-list"> <button class="btn btn-red" type="button" id="postMessage">postMessage</button> </div> </div> <script type="text/javascript"> var userAgent = navigator.userAgent; if (userAgent.indexOf('AlipayClient') > -1) { // 支付宝小程序的 JS-SDK 防止 404 需要动态加载,如果不需要兼容支付宝小程序,则无需引用此 JS 文件。 document.writeln('<script src="https://appx/web-view.min.js"' + '>' + '<' + '/' + 'script>'); } else if (/QQ/i.test(userAgent) && /miniProgram/i.test(userAgent)) { // QQ 小程序 document.write( '<script type="text/javascript" src="https://qqq.gtimg.cn/miniprogram/webview_jssdk/qqjssdk-1.0.0.js"><\/script>' ); } else if (/miniProgram/i.test(userAgent) && /micromessenger/i.test(userAgent)) { // 微信小程序 JS-SDK 如果不需要兼容微信小程序,则无需引用此 JS 文件。 document.write('<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"><\/script>'); } else if (/toutiaomicroapp/i.test(userAgent)) { // 头条小程序 JS-SDK 如果不需要兼容头条小程序,则无需引用此 JS 文件。 document.write( '<script type="text/javascript" src="https://s3.pstatp.com/toutiao/tmajssdk/jssdk-1.0.1.js"><\/script>'); } else if (/swan/i.test(userAgent)) { // 百度小程序 JS-SDK 如果不需要兼容百度小程序,则无需引用此 JS 文件。 document.write( '<script type="text/javascript" src="https://b.bdstatic.com/searchbox/icms/searchbox/js/swan-2.0.18.js"><\/script>' ); } else if (/quickapp/i.test(userAgent)) { // quickapp document.write('<script type="text/javascript" src="https://quickapp/jssdk.webview.min.js"><\/script>'); } if (!/toutiaomicroapp/i.test(userAgent)) { document.querySelector('.post-message-section').style.visibility = 'visible'; } </script> <!-- uni 的 SDK --> <!-- 需要把 uni.webview.1.5.4.js 下载到自己的服务器 --> <script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"></script> <script type="text/javascript"> // 待触发 `UniAppJSBridgeReady` 事件后,即可调用 uni 的 API。 document.addEventListener('UniAppJSBridgeReady', function() { uni.postMessage({ data: { action: 'message' } }); uni.getEnv(function(res) { console.log('当前环境:' + JSON.stringify(res)); }); document.querySelector('.btn-list').addEventListener('click', function(evt) { var target = evt.target; if (target.tagName === 'BUTTON') { var action = target.getAttribute('data-action'); switch (action) { case 'switchTab': uni.switchTab({ url: '/pages/tabBar/API/API' }); break; case 'reLaunch': uni.reLaunch({ url: '/pages/tabBar/component/component' }); break; case 'navigateBack': uni.navigateBack({ delta: 1 }); break; default: uni[action]({ url: '/pages/component/button/button' }); break; } } }); document.getElementById('postMessage').addEventListener('click', function() { uni.postMessage({ data: { action: 'message' } }); }); }); </script> </body></html>如何Uniapp中嵌入H5,并且在H5中跳转到APP的指定页面(uniapp 嵌套webview)

在这里我们提取出关键的代码

<!-- 需要把 uni.webview.1.5.4.js 下载到自己的服务器 --> 导入web-view 的SDK <script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"></script>调用方法跳转至app 的页面的关键方法 uni.reLaunchuni.reLaunch({ url: '/pages/tabBar/component/component' });

这个方法是跳转到APP的指定页面,url就是APP页面的路径,在APP项目中目录结构如下

对于这几个跳转方法可以自己去学习

case 'switchTab': uni.switchTab({ url: '/pages/tabBar/API/API' }); break; case 'reLaunch': uni.reLaunch({ url: '/pages/tabBar/component/component' }); break; case 'navigateBack': uni.navigateBack({ delta: 1 }); break;以上代码可以解决APP嵌入原生H5页面跳转回APP的问题,但是使用uniapp开发H5就会失效,在uniapp开发H5页面使用 uni.reLaunch 只能跳转到H5项目本地的页面。解决方法如下1. 下载官网web-view的SDK

在官网的原生H5 demo 导入了这个关键的Js文件,通过浏览器打开 https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js 复制里面的JS代码 在H5项目里创建一个js文件 web-view.js,内容即是以上js代码

2. 在H5项目的main.js 文件里导入这个文件

3. 原生H5使用的跳转方法和uniapp开发的H5使用的跳转方法是不一样的uni.webView.reLaunch({url: '/pages/tabBar/component/component'});

区别在于 uniapp开发的H5要加上 webView

本文链接地址:https://www.jiuchutong.com/zhishi/280073.html 转载请保留说明!

上一篇:Linux中遇到device is busy的处理方法(linux device drivers)

下一篇:路由器的默认网关是多少详情(路由器的默认网关在哪里看)

  • 企业内容营销战略转型到底转什么?(企业的内容营销)

    企业内容营销战略转型到底转什么?(企业的内容营销)

  • 华为手机如何下拉显示通知栏(华为手机如何下载chatGPT手机版)

    华为手机如何下拉显示通知栏(华为手机如何下载chatGPT手机版)

  • 达尔优鼠标dpi怎么调(达尔优鼠标dpi怎么调1200)

    达尔优鼠标dpi怎么调(达尔优鼠标dpi怎么调1200)

  • 手机疯狂收到验证码怎么解决(手机疯狂收到验证短信)

    手机疯狂收到验证码怎么解决(手机疯狂收到验证短信)

  • word换行符怎么打(word换行符怎么不显示)

    word换行符怎么打(word换行符怎么不显示)

  • 手机后面放身份证消磁吗(手机后面可以放身份证吗)

    手机后面放身份证消磁吗(手机后面可以放身份证吗)

  • maya怎么导出视频(maya怎么导出视频怎么不清晰)

    maya怎么导出视频(maya怎么导出视频怎么不清晰)

  • 拼多多订单待确认是什么意思(拼多多订单待确认要多久)

    拼多多订单待确认是什么意思(拼多多订单待确认要多久)

  • 手机上方的hd是什么意思(手机上方的hd是什么意思为什么不显示)

    手机上方的hd是什么意思(手机上方的hd是什么意思为什么不显示)

  • lan不亮是怎么回事(lan灯都不亮)

    lan不亮是怎么回事(lan灯都不亮)

  • 光猫带路由器功能吗(光猫带路由器功能是什么意思)

    光猫带路由器功能吗(光猫带路由器功能是什么意思)

  • 手机怎么查看qq邮箱号(手机怎么查看qq的q龄)

    手机怎么查看qq邮箱号(手机怎么查看qq的q龄)

  • 为什么苹果热点老断(为什么苹果热点电脑搜不到)

    为什么苹果热点老断(为什么苹果热点电脑搜不到)

  • 新手机三个条码干什么用(新手机三个条码怎么弄)

    新手机三个条码干什么用(新手机三个条码怎么弄)

  • 手机qq会员怎么退款(手机qq会员怎么克隆qq好友)

    手机qq会员怎么退款(手机qq会员怎么克隆qq好友)

  • 光模块分单模和多模吗(光模块分单模和多模区分)

    光模块分单模和多模吗(光模块分单模和多模区分)

  • 京东预售定金能退款吗(京东预售定金能改定其它产品吗)

    京东预售定金能退款吗(京东预售定金能改定其它产品吗)

  • 蜂窝移动数据限制在哪(蜂窝移动数据1x)

    蜂窝移动数据限制在哪(蜂窝移动数据1x)

  • 怎么查qq个人轨迹(如何查qq个人轨迹)

    怎么查qq个人轨迹(如何查qq个人轨迹)

  • 美图秀秀怎么去掉人物(美图秀秀怎么去红眼)

    美图秀秀怎么去掉人物(美图秀秀怎么去红眼)

  • 字体文件中存放的汉字编码(字体文件存放 统信)

    字体文件中存放的汉字编码(字体文件存放 统信)

  • Linux下如何安装deb格式的安装包?deb安装包安装教程(linux怎么安装程序)

    Linux下如何安装deb格式的安装包?deb安装包安装教程(linux怎么安装程序)

  • 【若依框架 RuoYi-Vue Ruo-Yi-Plus 图片回显不显示问题,OSS文件上传】(若依框架入门)

    【若依框架 RuoYi-Vue Ruo-Yi-Plus 图片回显不显示问题,OSS文件上传】(若依框架入门)

  • 金蝶软件可以实现一键报税吗
  • 国际税收协定是怎样避税的
  • 保证人不承担责任(胜诉案例)
  • 员工过生日计入什么科目
  • 一般纳税人增值税可以抵扣吗
  • 哪些费用的进项税可以抵扣
  • 2020年个税全年累计扣除如何计算
  • 支票罚金
  • 股权转让与增资扩股的税务
  • 小规模纳税人标准2019
  • 分销佣金分配
  • 工资分两次发为什么分两次扣税?
  • 增值税普通发票怎么开
  • 节能减排奖励资金追回
  • 企业车辆保险费要按什么交印花税的
  • 小规模建筑工程
  • 销售后换回产品的账务处理怎么做?
  • 高新技术企业资格复核
  • 会计管理制度范本
  • adb是什么程序
  • 深入浅出stm8
  • system占用cpu过高怎么解决
  • 子公司接受母公司无偿划转的房屋如何缴纳房产税
  • php get post
  • 前端页面出现乱码
  • 装win7提示失败怎么办
  • 调入的无形资产记入哪里
  • 开发票的时候补差价怎么处理?
  • 梅林澳大利亚信号好最好吗
  • 什么情况下可以土葬
  • php输出语法
  • php获取长度
  • 攻防世界web高手题答案
  • linux ar命令
  • 员工工资费用
  • 劳务费过账
  • 本年利润的会计分录有哪些
  • 一般纳税人怎么转为小规模纳税人
  • mysql性能提升
  • 新政府会计制度下的基建会计
  • 总账和明细账期间相同吗
  • 又是客户又是供应商的舞弊行为
  • 小规模纳税人是小微企业吗
  • 电子发票的缺点
  • mysql数据库性能优化方法有哪些
  • 月未转出未交增值税
  • 小规模开票的税点是多少
  • 产品不符合要求
  • 小规模增值税减免
  • 实际上缴税费总额怎么算
  • 员工拿发票报销怎么做账
  • 预算会计年末如何结账
  • win8 无线网络连不上
  • wget下载命令
  • win8.1笔记本
  • ubuntu 8.04.1 LTS 下的cpu温度监控软件lm-sensors
  • windows8咋关机
  • linux查看磁盘io负载
  • windows8使用教程
  • win7系统打印机服务开启
  • cocos做游戏
  • 拉伸设置
  • JavaScript中的数据类型分为两大类
  • perl字符串替换 ~s
  • js document.cookie
  • android使用webview加载网页
  • 请问在javascript程序中
  • python中的字符型
  • python编写下载器
  • 关于两个人感情文案
  • [置顶]马粥街残酷史
  • 函数 python
  • js模拟点击事件onclick
  • 深圳市税务局官网电话号码
  • 河南国税局变更法人流程
  • 纳税申报期过了怎么申报
  • 手写发票属于增值税普通发票吗
  • 怎么使用企业级app
  • 推进落实类似的词语
  • 农副产品批发价
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设