• Home
Name Date Size #Lines LOC

..--

AppScope/22-Oct-2025-3532

entry/22-Oct-2025-725609

hvigor/22-Oct-2025-3836

screenshots/22-Oct-2025-

.gitignoreD22-Oct-2025144 1212

README.mdD22-Oct-20253.1 KiB7754

build-profile.json5D22-Oct-20251.4 KiB5756

code-linter.json5D22-Oct-2025992 3534

hvigorfile.tsD22-Oct-2025864 225

oh-package.json5D22-Oct-2025834 2624

ohosTest.mdD22-Oct-2025627 86

README.md

1# ArkTS使用JSVM-API实现JS与C/C++语言交互开发流程
2
3### 介绍
4
5使用JSVM-API实现跨语言交互,首先需要按照JSVM-API的机制实现模块的注册和加载等相关动作。
6
7- ArkTS/JS侧:实现C++方法的调用。代码比较简单,import一个对应的so库后,即可调用C++方法。
8- Native侧:.cpp文件,实现模块的注册。需要提供注册lib库的名称,并在注册回调方法中定义接口的映射关系,即Native方法及对应的JS/ArkTS接口名称等。
9
10该工程中展示的代码详细描述可查如下链接:
11
12- [使用JSVM-API实现JS与C/C++语言交互开发流程](https://docs.openharmony.cn/pages/v5.0/zh-cn/application-dev/napi/use-jsvm-process.md)
13
14### 效果预览
15
16|                              首页                               |                       执行及结果即时反馈                        |
17| :-------------------------------------------------------------: | :-------------------------------------------------------------: |
18| <img src="./screenshots/JsvmProcess_1.png" style="zoom:33%;" /> | <img src="./screenshots/JsvmProcess_2.png" style="zoom:33%;" /> |
19
20### 使用说明
21
221. 在主界面,可以点击Hello World,开始执行。
232. 执行结果会即时反馈在屏幕中央,并在控制台打印log。
24
25### 工程目录
26
27```
28entry/src/
29 ├── main
30 │   ├── cpp
31 │   │   ├── types
32 │   │   │   ├── libentry
33 │   │   │   │   ├── Index.d.ts          // 使用JSVM-API实现JS与C/C++语言交互开发流程示例代码
34 │   │   │   │   ├── oh-package.json5 	 // 使用JSVM-API实现JS与C/C++语言交互开发流程示例代码
35 │   │   ├── CMakeLists.txt              // 使用JSVM-API实现JS与C/C++语言交互开发流程示例代码
36 │   │   ├── hello.cpp                   // 使用JSVM-API实现JS与C/C++语言交互开发流程示例代码
37 │   ├── ets
38 │   │   ├── entryability
39 │   │   ├── entrybackupability
40 │   │   ├── pages
41 │   │       ├── Index.ets               // 使用JSVM-API实现JS与C/C++语言交互开发流程示例代码
42 │   ├── module.json5
43 │   └── resources
44 ├── ohosTest
45 │   ├── ets
46 │   │   ├── test
47 │   │       ├── Ability.test.ets        // 自动化测试代码
48```
49
50### 相关权限
51
52不涉及。
53
54### 依赖
55
56不涉及。
57
58### 约束与限制
59
601.本示例仅支持标准系统上运行, 支持设备:Phone。
61
622.本示例为Stage模型,支持API15版本SDK,版本号:5.0.3.135,镜像版本号:HarmonyOS NEXT_5.0.3.135。
63
643.本示例需要使用DevEco Studio 5.0.3 Release (Build Version: 5.0.9.300, built on March 13, 2025)及以上版本才可编译运行。
65
66### 下载
67
68如需单独下载本工程,执行如下命令:
69
70```
71git init
72git config core.sparsecheckout true
73echo code/DocsSample/ArkTS/JSVMAPI/JsvmProcess > .git/info/sparse-checkout
74git remote add origin https://gitee.com/openharmony/applications_app_samples.git
75git pull origin master
76```
77