Uniapp 与 H5 在 App 端的交互

一、整体调用逻辑框架

Uniapp 开发的 App 中嵌入 H5 页面(通过 web-view 组件)时,二者的交互核心围绕 Uniapp 向 H5 传值/触发方法H5 向 Uniapp 通信 两层,其中 Uniapp 侧对 web-view 元素的操作是关键枢纽。

二、Uniapp 侧核心逻辑(获取 web-view 元素 + 传值/触发方法)
  1. 获取 web-view 元素

    • 核心方式:通过 uni.createSelectorQuery() 获取 web-view 组件的 DOM 节点(需在组件挂载完成后执行,如 onReady/mounted 生命周期)。

    • 关键代码逻辑:

      javascript 复制代码
      // 1. 创建选择器查询对象
      const query = uni.createSelectorQuery().in(this); 
      // 2. 定位 web-view 元素(通过 ref 或类名/ID)
      query.select('#web-view-id').fields({ node: true, size: true }).exec((res) => {
        if (res[0]) {
          this.webViewElement = res[0].node; // 缓存 web-view 元素,供后续操作
        }
      });
    • 注意点:in(this) 必须加(指定组件上下文),否则在自定义组件中无法获取元素;需确保 web-view 已渲染完成(避免异步获取不到)。

  2. 向 H5 传值/触发 H5 方法

    Uniapp 向 H5 通信的核心是 evalJS 方法(仅 App 端支持),通过该方法执行 H5 页面的 JS 代码,实现传值或触发方法:

    • 传值逻辑:将参数序列化(如 JSON.stringify)后,拼接到 H5 方法调用的代码字符串中,通过 evalJS 执行。

      javascript 复制代码
      // 假设 H5 页面有全局方法 receiveDataFromUniapp
      const data = { id: 1, name: 'test' };
      // 缓存的 web-view 元素调用 evalJS
      this.webViewElement.evalJS(`receiveDataFromUniapp(${JSON.stringify(data)})`);
    • 触发 H5 方法逻辑:直接通过 evalJS 执行 H5 全局方法名,无需传值时简化为:

      javascript 复制代码
      this.webViewElement.evalJS(`triggerH5Method()`);
    • 边界处理:若传值包含特殊字符(如引号),需做转义;H5 侧方法必须挂载到 window 全局对象上,否则 Uniapp 无法调用。

三、H5 侧响应逻辑(辅助 Uniapp 交互)
  1. H5 需提前定义全局方法(供 Uniapp 调用):

    javascript 复制代码
    // H5 页面
    window.receiveDataFromUniapp = function(data) {
      // 处理 Uniapp 传递的参数
      console.log('来自Uniapp的数据:', data);
    };
    
    window.triggerH5Method = function() {
      // 执行 H5 自身业务逻辑
    };
  2. H5 向 Uniapp 通信(补充):通过 uni.postMessage(小程序/App 通用)或 App 端 plus.webview.postMessage,但核心交互仍以 Uniapp 主动操作为主。

四、关键总结
  1. Uniapp 端获取 web-view 是前提:依赖 selectorQuery,需在组件渲染完成后执行,且需指定上下文 in(this)
  2. 传值/触发方法的核心是 evalJS:通过执行 H5 全局 JS 方法实现通信,参数需序列化避免语法错误。
  3. H5 端需暴露全局方法:方法必须挂载到 window 上,否则 Uniapp 无法通过 evalJS 调用。
  4. 仅 App 端生效:evalJS 是 Uniapp 针对 App 端 web-view 的特有 API,H5/小程序端需用其他方式(如 postMessage)。
相关推荐
杨超越luckly2 小时前
Agent应用指南:利用GET请求获取赛力斯汽车门店位置信息
python·html·汽车·可视化·门店
可别3902 小时前
Vue 极简实现语音实时转写(录音转文字,低网络依赖、开箱即用)
前端·javascript·vue.js
小雨下雨的雨2 小时前
数独算法与求解器鸿蒙PC Electron框架完成深度解析
javascript·人工智能·算法·游戏·华为·electron·鸿蒙系统
阿猫的故乡2 小时前
Vue插槽从入门到项目实战:默认插槽、具名插槽、作用域插槽,一次讲明白
前端·javascript·vue.js
SEO-狼术2 小时前
Build Interactive Maps Crack
前端
小则又沐风a2 小时前
进程最终篇---进程控制(模拟实现xshell)
java·linux·服务器·前端
川冰ICE2 小时前
JavaScript工程化②|Webpack5基础配置,打包你的第一个项目
开发语言·javascript·ecmascript
YHHLAI2 小时前
JavaScript 同步异步精讲:单线程、事件循环、Promise 执行机制
开发语言·javascript·ecmascript
Web打印2 小时前
HttpPrinter web打印控件 官方文档(https://wiki.httpprinter.com/)快速检索目录
java·javascript·chrome