在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解
一、Web-view 简介
Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面:
- 支持加载本地 HTML 文件
- 支持加载远程 HTML 页面
- 实现 Web 与原生的双向通讯
- 可用于嵌入第三方网页或 H5 应用
二、Web-view 加载 HTML 的方式
1. 加载本地 HTML 文件
<template><view><web-view :src="localHtmlPath"></web-view></view>
</template><script setup>
import { ref, onLoad } from 'vue';const localHtmlPath = ref('');onLoad(() => {// 本地 HTML 文件路径localHtmlPath.value = '/static/html/index.html';
});
</script>
2. 加载远程 HTML 页面
<template><view><web-view :src="remoteUrl"></web-view></view>
</template><script setup>
import { ref, onLoad } from 'vue';const remoteUrl = ref('');onLoad(() => {// 远程 HTML 页面 URLremoteUrl.value = 'https://www.example.com';
});
</script>
三、Web-view 与 Vue 页面的通讯方式
1. H5 页面向 uni-app 发送消息
在 H5 页面中:
// H5 页面 (index.html)
function sendMessageToUniApp() {// 方式一:使用 postMessage (推荐)window.uni.postMessage({type: 'getData',data: {name: '张三',age: 25}});// 方式二:使用自定义 JSBridge (兼容旧版本)if (window.webkit && window.webkit.messageHandlers && window.webkit.messageHandlers.uni) {// iOS 平台window.webkit.messageHandlers.uni.postMessage({type: 'getData',data: {name: '张三',age: 25}});} else if (window.uni) {// Android 平台window.uni.postMessage(JSON.stringify({type: 'getData',data: {name: '张三',age: 25}}));}
}
在 uni-app 页面中接收消息:
<template><view><web-view :src="htmlPath" @message="handleMessage"></web-view></view>
</template><script setup>
import { ref } from 'vue';const htmlPath = ref('/static/html/index.html');const handleMessage = (e) => {const data = e.detail.data[0];console.log('收到 H5 消息:', data);// 根据消息类型处理if (data.type === 'getData') {// 处理数据console.log('用户信息:', data.data);}
};
</script>
2. uni-app 向 H5 页面发送消息
在 uni-app 页面中:
<template><view><button @click="sendToH5">向 H5 发送消息</button><web-view ref="webviewRef" :src="htmlPath"></web-view></view>
</template><script setup>
import { ref } from 'vue';const webviewRef = ref(null);
const htmlPath = ref('/static/html/index.html');const sendToH5 = () => {// 向 H5 发送消息webviewRef.value.postMessage({type: 'setData',data: {title: '来自 uni-app 的数据',content: '这是一条从 uni-app 发送到 H5 的消息'}});
};
</script>
在 H5 页面中接收消息:
// H5 页面 (index.html)
// 监听 uni-app 发送的消息
window.addEventListener('message', (e) => {const data = e.data;console.log('收到 uni-app 消息:', data);// 根据消息类型处理if (data.type === 'setData') {// 更新页面内容document.getElementById('title').innerText = data.data.title;document.getElementById('content').innerText = data.data.content;}
});
四、在 H5 页面中调用 uni-app API
1. 使用 postMessage 间接调用
在 H5 页面中:
// H5 页面 (index.html)
function callUniAppAPI() {// 请求调用 uni-app APIwindow.uni.postMessage({type: 'callAPI',apiName: 'getLocation',params: {type: 'wgs84'}});
}
在 uni-app 页面中:
<template><view><web-view :src="htmlPath" @message="handleMessage"></web-view></view>
</template><script setup>
import { ref } from 'vue';const htmlPath = ref('/static/html/index.html');
const webviewRef = ref(null);const handleMessage = (e) => {const data = e.detail.data[0];// 处理 API 调用请求if (data.type === 'callAPI') {const { apiName, params } = data;// 根据 API 名称调用相应的 uni-app APIif (apiName === 'getLocation') {uni.getLocation({...params,success: (res) => {// 将结果返回给 H5 页面webviewRef.value.postMessage({type: 'apiResult',apiName,success: true,result: res});},fail: (err) => {// 将错误返回给 H5 页面webviewRef.value.postMessage({type: 'apiResult',apiName,success: false,error: err});}});}// 可以添加更多 API 的处理}
};
</script>
在 H5 页面中接收 API 结果:
// H5 页面 (index.html)
window.addEventListener('message', (e) => {const data = e.data;// 处理 API 调用结果if (data.type === 'apiResult') {if (data.success) {console.log('API 调用成功:', data.result);// 更新页面显示document.getElementById('location').innerText = `纬度: ${data.result.latitude}, 经度: ${data.result.longitude}`;} else {console.error('API 调用失败:', data.error);// 显示错误信息document.getElementById('location').innerText = '获取位置失败';}}
});
2. 使用 JSBridge 直接调用
在 uni-app 页面中注入 JSBridge:
<template><view><web-view ref="webviewRef" :src="htmlPath" @message="handleMessage"></web-view></view>
</template><script setup>
import { ref, onReady } from 'vue';const webviewRef = ref(null);
const htmlPath = ref('/static/html/index.html');onReady(() => {// 注入 JSBridgeconst jsStr = `window.uniAPI = {getLocation: function(callback) {window.uni.postMessage({type: 'callAPI',apiName: 'getLocation',callbackId: 'getLocation_' + Date.now()});// 存储回调函数window.uniAPI._callbacks['getLocation_' + Date.now()] = callback;},_callbacks: {}};`;// 执行 JS 代码注入 JSBridgewebviewRef.value.evalJs(jsStr);
});const handleMessage = (e) => {const data = e.detail.data[0];// 处理 API 调用结果if (data.type === 'apiResult') {const callback = window.uniAPI._callbacks[data.callbackId];if (callback) {callback(data.success ? data.result : null, data.success ? null : data.error);delete window.uniAPI._callbacks[data.callbackId];}}
};
</script>
在 H5 页面中使用 JSBridge:
// H5 页面 (index.html)
function getLocation() {// 使用 JSBridge 调用 uni-app APIwindow.uniAPI.getLocation((result, error) => {if (result) {console.log('获取位置成功:', result);document.getElementById('location').innerText = `纬度: ${result.latitude}, 经度: ${result.longitude}`;} else {console.error('获取位置失败:', error);document.getElementById('location').innerText = '获取位置失败';}});
}
五、注意事项与最佳实践
-
跨域问题
- 加载远程 HTML 时需确保域名在白名单中
- 在
manifest.json
中配置h5
→domains
-
性能优化
- 避免频繁通讯
- 使用批量数据传输
- 对数据进行压缩处理
-
安全考虑
- 验证消息来源
- 对敏感操作进行权限控制
- 避免在 URL 中传递敏感信息
-
兼容性处理
- 处理不同平台的差异
- 提供降级方案
- 进行充分测试
-
调试技巧
- 使用 HBuilderX 的调试工具
- 在 H5 页面中添加日志输出
- 使用浏览器开发者工具调试
六、常见问题解决方案
-
消息接收不及时
- 确保 web-view 组件已加载完成
- 使用定时器重试机制
-
API 调用失败
- 检查 API 名称和参数是否正确
- 确认 API 权限是否已获取
- 处理 API 调用超时情况
-
内存泄漏
- 及时清理不再使用的回调函数
- 避免创建过多的临时对象
- 合理管理消息队列
-
性能问题
- 减少跨边界通讯次数
- 批量处理数据
- 对大数据进行分片传输
通过以上方法,您可以在 uni-app 中实现 Web-view 与 Vue 页面的高效通讯,为用户提供更丰富的交互体验。
相关文章:
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面: 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...
Mobile ALOHA全身模仿学习
一、题目 Mobile ALOHA:通过低成本全身远程操作学习双手移动操作 传统模仿学习(Imitation Learning)缺点:聚焦与桌面操作,缺乏通用任务所需的移动性和灵活性 本论文优点:(1)在ALOHA…...

Springboot社区养老保险系统小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,社区养老保险系统小程序被用户普遍使用,为方…...

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题
在数字化浪潮席卷全球的今天,软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件,这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下,实现高效测试与快速迭代?这一命题正考验着…...

ABAP设计模式之---“简单设计原则(Simple Design)”
“Simple Design”(简单设计)是软件开发中的一个重要理念,倡导以最简单的方式实现软件功能,以确保代码清晰易懂、易维护,并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计,遵循“让事情保…...

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据
微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据 Power Query 具有大量专门帮助您清理和准备数据以供分析的功能。 您将了解如何简化复杂模型、更改数据类型、重命名对象和透视数据。 您还将了解如何分析列,以便知晓哪些列包含有价值的数据,…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...

USB Over IP专用硬件的5个特点
USB over IP技术通过将USB协议数据封装在标准TCP/IP网络数据包中,从根本上改变了USB连接。这允许客户端通过局域网或广域网远程访问和控制物理连接到服务器的USB设备(如专用硬件设备),从而消除了直接物理连接的需要。USB over IP的…...

算法笔记2
1.字符串拼接最好用StringBuilder,不用String 2.创建List<>类型的数组并创建内存 List arr[] new ArrayList[26]; Arrays.setAll(arr, i -> new ArrayList<>()); 3.去掉首尾空格...
MySQL账号权限管理指南:安全创建账户与精细授权技巧
在MySQL数据库管理中,合理创建用户账号并分配精确权限是保障数据安全的核心环节。直接使用root账号进行所有操作不仅危险且难以审计操作行为。今天我们来全面解析MySQL账号创建与权限分配的专业方法。 一、为何需要创建独立账号? 最小权限原则…...
Java 二维码
Java 二维码 **技术:**谷歌 ZXing 实现 首先添加依赖 <!-- 二维码依赖 --><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.5.1</version></dependency><de…...

听写流程自动化实践,轻量级教育辅助
随着智能教育工具的发展,越来越多的传统学习方式正在被数字化、自动化所优化。听写作为语文、英语等学科中重要的基础训练形式,也迎来了更高效的解决方案。 这是一款轻量但功能强大的听写辅助工具。它是基于本地词库与可选在线语音引擎构建,…...

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)
上一章用到了V2 的概念,其实 Fiori当中还有 V4,咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务),代理中间件(ui5-middleware-simpleproxy)-CSDN博客…...

AI,如何重构理解、匹配与决策?
AI 时代,我们如何理解消费? 作者|王彬 封面|Unplash 人们通过信息理解世界。 曾几何时,PC 与移动互联网重塑了人们的购物路径:信息变得唾手可得,商品决策变得高度依赖内容。 但 AI 时代的来…...
rnn判断string中第一次出现a的下标
# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...

Unsafe Fileupload篇补充-木马的详细教程与木马分享(中国蚁剑方式)
在之前的皮卡丘靶场第九期Unsafe Fileupload篇中我们学习了木马的原理并且学了一个简单的木马文件 本期内容是为了更好的为大家解释木马(服务器方面的)的原理,连接,以及各种木马及连接工具的分享 文件木马:https://w…...

深度学习习题2
1.如果增加神经网络的宽度,精确度会增加到一个特定阈值后,便开始降低。造成这一现象的可能原因是什么? A、即使增加卷积核的数量,只有少部分的核会被用作预测 B、当卷积核数量增加时,神经网络的预测能力会降低 C、当卷…...
Angular微前端架构:Module Federation + ngx-build-plus (Webpack)
以下是一个完整的 Angular 微前端示例,其中使用的是 Module Federation 和 npx-build-plus 实现了主应用(Shell)与子应用(Remote)的集成。 🛠️ 项目结构 angular-mf/ ├── shell-app/ # 主应用&…...
重启Eureka集群中的节点,对已经注册的服务有什么影响
先看答案,如果正确地操作,重启Eureka集群中的节点,对已经注册的服务影响非常小,甚至可以做到无感知。 但如果操作不当,可能会引发短暂的服务发现问题。 下面我们从Eureka的核心工作原理来详细分析这个问题。 Eureka的…...
Pinocchio 库详解及其在足式机器人上的应用
Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库,专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性,并提供了一个通用的框架&…...

10-Oracle 23 ai Vector Search 概述和参数
一、Oracle AI Vector Search 概述 企业和个人都在尝试各种AI,使用客户端或是内部自己搭建集成大模型的终端,加速与大型语言模型(LLM)的结合,同时使用检索增强生成(Retrieval Augmented Generation &#…...

Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...
Android第十三次面试总结(四大 组件基础)
Activity生命周期和四大启动模式详解 一、Activity 生命周期 Activity 的生命周期由一系列回调方法组成,用于管理其创建、可见性、焦点和销毁过程。以下是核心方法及其调用时机: onCreate() 调用时机:Activity 首次创建时调用。…...
安卓基础(aar)
重新设置java21的环境,临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的: MyApp/ ├── app/ …...
Hive 存储格式深度解析:从 TextFile 到 ORC,如何选对数据存储方案?
在大数据处理领域,Hive 作为 Hadoop 生态中重要的数据仓库工具,其存储格式的选择直接影响数据存储成本、查询效率和计算资源消耗。面对 TextFile、SequenceFile、Parquet、RCFile、ORC 等多种存储格式,很多开发者常常陷入选择困境。本文将从底…...

华硕a豆14 Air香氛版,美学与科技的馨香融合
在快节奏的现代生活中,我们渴望一个能激发创想、愉悦感官的工作与生活伙伴,它不仅是冰冷的科技工具,更能触动我们内心深处的细腻情感。正是在这样的期许下,华硕a豆14 Air香氛版翩然而至,它以一种前所未有的方式&#x…...

云原生玩法三问:构建自定义开发环境
云原生玩法三问:构建自定义开发环境 引言 临时运维一个古董项目,无文档,无环境,无交接人,俗称三无。 运行设备的环境老,本地环境版本高,ssh不过去。正好最近对 腾讯出品的云原生 cnb 感兴趣&…...

以光量子为例,详解量子获取方式
光量子技术获取量子比特可在室温下进行。该方式有望通过与名为硅光子学(silicon photonics)的光波导(optical waveguide)芯片制造技术和光纤等光通信技术相结合来实现量子计算机。量子力学中,光既是波又是粒子。光子本…...
Python 包管理器 uv 介绍
Python 包管理器 uv 全面介绍 uv 是由 Astral(热门工具 Ruff 的开发者)推出的下一代高性能 Python 包管理器和构建工具,用 Rust 编写。它旨在解决传统工具(如 pip、virtualenv、pip-tools)的性能瓶颈,同时…...

html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码
目录 一、👨🎓网站题目 二、✍️网站描述 三、📚网站介绍 四、🌐网站效果 五、🪓 代码实现 🧱HTML 六、🥇 如何让学习不再盲目 七、🎁更多干货 一、👨…...