| Name | Date | Size | #Lines | LOC | ||
|---|---|---|---|---|---|---|
| .. | - | - | ||||
| AppScope/ | 22-Oct-2025 | - | 35 | 32 | ||
| entry/ | 22-Oct-2025 | - | 725 | 609 | ||
| hvigor/ | 22-Oct-2025 | - | 38 | 36 | ||
| screenshots/ | 22-Oct-2025 | - | ||||
| .gitignore | D | 22-Oct-2025 | 144 | 12 | 12 | |
| README.md | D | 22-Oct-2025 | 3.1 KiB | 77 | 54 | |
| build-profile.json5 | D | 22-Oct-2025 | 1.4 KiB | 57 | 56 | |
| code-linter.json5 | D | 22-Oct-2025 | 992 | 35 | 34 | |
| hvigorfile.ts | D | 22-Oct-2025 | 864 | 22 | 5 | |
| oh-package.json5 | D | 22-Oct-2025 | 834 | 26 | 24 | |
| ohosTest.md | D | 22-Oct-2025 | 627 | 8 | 6 |
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