鸿蒙开发 web js 与ArkTS 交互最小化例子

下面给出「Web JavaScript ↔ ArkTS」双向通信的最小可运行例子, 全部代码复制到 DevEco Studio 即可直接跑通(API 11+,ArkTS Stage 模型)。 思路:用 Web 组件的 javaScriptProxy 把 ArkTS 对象注入到 H5 的 window 下, H5 调用注入方法即可把数据推到 ArkTS;反过来 ArkTS 用 runJavaScript 即可把数据推回 H5。


1. 目录结构

ts 复制代码
entry/src/main/ets/pages/Index.ets
entry/src/main/resources/rawfile/index.html   // 放 H5

2. ArkTS 侧(Index.ets)

typescript 复制代码
import web_webview from '@ohos.web.webview';

interface JsBridge {
  sendToArkTS(msg: string): string;
}

class JsBridgeImpl implements JsBridge {
  sendToArkTS(msg: string): string {
    console.info('Web说:' + msg);
    return 'ArkTS 已收到:' + msg;
  }
}

@Entry
@Component
struct WebJSArkTSConn {
  private webCtrl = new web_webview.WebviewController();

  private jsBridge: JsBridge = new JsBridgeImpl();

  build() {
    Column() {
      Button('ArkTS → Web')
        .onClick(() => {
          // 2. ArkTS 主动调 H5 函数
          this.webCtrl.runJavaScript(`receiveFromArkTS('Hello, I am ArkTS!')`);
        })

      Web({ src: $rawfile('index_2.html'), controller: this.webCtrl })
        .javaScriptAccess(true)
        .javaScriptProxy({
          object: this.jsBridge,
          name: 'ArkTSBridge',   // 注入到 window 的变量名
          methodList: ['sendToArkTS'],
          controller: this.webCtrl
        })
        .width('100%')
        .height('100%')
    }
  }
}

3. Web 侧(index.html)

html 复制代码
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS ↔ ArkTS</title>
</head>
<body>
  <button onclick="sendToArkTS()">Web → ArkTS</button>
  <div id="result">等待 ArkTS 返回...</div>

  <script>
    // 被 ArkTS 调用的函数
    function receiveFromArkTS(msg) {
      document.getElementById('result').innerText = '收到 ArkTS:' + msg;
    }

    // 调用注入的对象
    function sendToArkTS() {
      if (window.ArkTSBridge && window.ArkTSBridge.sendToArkTS) {
        const ret = window.ArkTSBridge.sendToArkTS('Hello, I am Web!');
        document.getElementById('result').innerText = 'ArkTS 返回:' + ret;
      } else {
        alert('ArkTSBridge 未就绪');
      }
    }
  </script>
</body>
</html>

4. 运行效果

  • 「Web → ArkTS」 → H5 把字符串传给 ArkTS,立即拿到回执并显示。
  • 「ArkTS → Web」 → ArkTS 主动把字符串推给 H5,页面实时刷新。

5. 注意事项

  1. javaScriptProxymethodList 必须显式列出,否则方法不可见。
  2. 如果后续需要双向异步事件,可再包一层 postMessage/onMessageEvent 做事件总线 。
  3. 调试阶段在 onPageEnd 回调里 runJavaScript 可确保 H5 已加载完成再调函数。

至此,最小双向通信完成,可在此基础上扩展任意复杂逻辑。祝开发顺利!

异常情况

ts 复制代码
private jsBridge = {
// H5 调用的函数
sendToArkTS: (msg: string): string => {
console.info('Web说:' + msg);
// 可在这里把数据回显到 UI 或发回 H5
return 'ArkTS 已收到:' + msg;
}
};

语法有Object literal must correspond to some explicitly declared class or interface (arkts-no-untyped-obj-literals) <ArkTSCheck

ts 复制代码
private jsBridge : JsBridge = {
// H5 调用的函数
sendToArkTS: (msg: string): string => {
console.info('Web说:' + msg);
// 可在这里把数据回显到 UI 或发回 H5
return 'ArkTS 已收到:' + msg;
}
}as JsBridge;

一样有语法问题 arkts-no-untyped-obj-literals

鸿蒙开发有比较严格的语法检查,不同于 js 和 ts 的随意写法,一般都是 interface 和 class 以及 new 这三者组合完成对象实例化

相关推荐
cehuishi95277 分钟前
python和arcgispro的实践(AI辅助编程)
服务器·前端·python
Summer不秃14 分钟前
使用 SnapDOM + jsPDF 生成高质量 PDF (含多页分页, 附源码)
前端·javascript·vue.js·pdf·node.js
AC赳赳老秦20 分钟前
工业互联网赋能智造:DeepSeek解析产线传感器数据驱动质量管控新范式
前端·数据库·人工智能·zookeeper·json·flume·deepseek
Student_Zhang41 分钟前
一个管理项目中所有弹窗的弹窗管理器(PopupManager)
前端·ios·github
网络风云42 分钟前
HTML 模块化方案
前端·html
灯把黑夜烧了一个洞44 分钟前
2026年跨年倒计时网页版
javascript·css·html·2026跨年代码·新年代码
小满zs1 小时前
Next.js第十九章(服务器函数)
前端·next.js
仰望.1 小时前
vxe-table 如何实现分页勾选复选框功能,分页后还能支持多选的选中状态
前端·vue.js·vxe-table
zhenryx1 小时前
React Native 横向滚动指示器组件库(淘宝|京东...&旧版|新版)
javascript·react native·react.js
铅笔侠_小龙虾1 小时前
html+css 实现键盘
前端·css·html