HarmonyOS 鸿蒙Next napi_new_instance的使用

发布于 1周前 作者 ionicwang 来自 鸿蒙OS

HarmonyOS 鸿蒙Next napi_new_instance的使用 怎么在 c/c++ 创建 ts 的对象,尝试从 global 里面通过类的名称获取类的构造函数(然后通过 new_instance 构造对象),但是返回的构造函数是个 undefine 的类型

2 回复

napi_status status = napi_get_named_property(env, args[0], "Singleton", & constructor);删掉就可以了, napi_status status = napi_new_instance(env, constructor, NULL, NULL, & instance);不需要使用获取方法的方式获取构造函数,constructor不是class的构造函数,直接传接受的class就行了。

static napi_value NativeCallArkTS(napi_env env, napi_callback_info info) {
    // 期望从ArkTS侧获取的参数的数量,napi_value可理解为ArkTS value在native方法中的表现形式。
    size_t argc = 1;
    napi_value args[1] = { nullptr };

    // 从info中,拿到从ArkTS侧传递过来的参数,此处获取了一个ArkTS参数,即arg[0]。
    napi_get_cb_info(env, info, & argc, args, nullptr, nullptr);

    napi_value instance;
    napi_status status = napi_new_instance(env, args[0], NULL, NULL, & instance);

    napi_value func;
    napi_get_named_property(env, instance, "add", & func);

    napi_value res;
    napi_create_double(env, 10, & res);

    napi_value result;
    napi_call_function(env, instance, func, 1, & res, & result);

    return result;
}

更多关于HarmonyOS 鸿蒙Next napi_new_instance的使用的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS(鸿蒙)系统中,napi_new_instance 是用于创建新的JavaScript实例的函数,通常与N-API(Node.js API for Native Modules)相关,用于在原生代码中与JavaScript交互。在鸿蒙的某些场景中,尤其是涉及原生模块与JavaScript环境交互的应用开发时,这个函数可能会用到。

napi_new_instance的基本使用流程如下:

  1. 准备环境:确保已经初始化了一个 napi_env 环境,这是所有N-API调用的基础。

  2. 定义构造函数:你需要有一个已经定义的JavaScript类(通过 napi_define_classes 等函数注册),其构造函数将用于创建新实例。

  3. 调用 napi_new_instance:使用该构造函数和可选的初始化参数数组,调用 napi_new_instance 来创建新的JavaScript对象实例。

  4. 处理返回值:检查返回值以确保实例创建成功,并处理任何潜在的错误。

示例代码框架(省略具体实现细节):

napi_value constructor;
napi_value instance;
napi_status status = napi_get_reference_value(env, constructor_ref, &constructor);
if (status == napi_ok) {
    size_t argc = 1;
    napi_value argv[1] = {arg1}; // 初始化参数
    status = napi_new_instance(env, constructor, argc, argv, &instance);
}
// 检查 status 并处理实例 instance
``

如果问题依旧没法解决请联系官网客服, 官网地址是 [https://www.itying.com/category-93-b0.html](https://www.itying.com/category-93-b0.html)
回到顶部