harmony 鸿蒙Node-API

  • 2025-06-16
  • 浏览 (1)

Node-API

简介

Node-API是用于封装JavaScript能力为Native插件的API,独立于底层JavaScript,并作为Node.js的一部分。

支持的能力

Node-API可以去除底层的JavaScript引擎的差异,提供一套稳定的接口。

OpenHarmony的Node-API组件对Node-API的接口进行了重新实现,底层对接了ArkJS等引擎。当前支持Node-API标准库中的部分接口。

引入Node-API能力

如果开发者需要使用Node-API相关功能,首先请添加头文件:

#include <napi/native_api.h>

其次在CMakeLists.txt中添加以下动态链接库:

libace_napi.z.so

已从Node-API组件标准库中导出的符号列表

从Node-API标准库导出的接口,其使用方法及行为基于Node.js,并进行了部分能力拓展

符号类型 符号名 说明 起始支持API版本
FUNC napi_module_register napi native模块注册接口。 10
FUNC napi_get_last_error_info 获取napi_extended_error_info结构体,其中包含最近一次出现的error信息。 10
FUNC napi_throw 抛出一个js value。 10
FUNC napi_throw_error 抛出一个带文本信息的js Error 10
FUNC napi_throw_type_error 抛出一个带文本信息的js TypeError 10
FUNC napi_throw_range_error 抛出一个带文本信息的js RangeError 10
FUNC napi_is_error 判断napi_value是否表示为一个error对象。 10
FUNC napi_create_error 创建并获取一个带文本信息的js Error 10
FUNC napi_create_type_error 创建并获取一个带文本信息的js TypeError 10
FUNC napi_create_range_error 创建并获取一个带文本信息的js RangeError 10
FUNC napi_get_and_clear_last_exception 获取并清除最近一次出现的异常。 10
FUNC napi_is_exception_pending 判断是否出现了异常。 10
FUNC napi_fatal_error 引发致命错误以立即终止进程。 10
FUNC napi_open_handle_scope 创建一个上下文环境使用。 10
FUNC napi_close_handle_scope 关闭传入的上下文环境,关闭后,全部在其中声明的引用都将被关闭。 10
FUNC napi_open_escapable_handle_scope 创建出一个可逃逸的handle scope,可将范围内声明的值返回到父作用域。 10
FUNC napi_close_escapable_handle_scope 关闭传入的可逃逸的handle scope。 10
FUNC napi_escape_handle 提升传入的js object的生命周期到其父作用域。 10
FUNC napi_create_reference Object创建一个reference,以延长其生命周期。调用者需要自己管理reference生命周期。 10
FUNC napi_delete_reference 删除传入的reference。 10
FUNC napi_reference_ref 增加传入的reference的引用计数,并获取该计数。 10
FUNC napi_reference_unref 减少传入的reference的引用计数,并获取该计数。 10
FUNC napi_get_reference_value 获取与reference相关联的js Object 10
FUNC napi_create_array 创建并获取一个js Array 10
FUNC napi_create_array_with_length 创建并获取一个指定长度的js Array 10
FUNC napi_create_arraybuffer 创建并获取一个指定大小的js ArrayBuffer 10
FUNC napi_create_external 分配一个附加有外部数据的js value。 10
FUNC napi_create_external_arraybuffer 分配一个附加有外部数据的js ArrayBuffer 10
FUNC napi_create_object 创建一个默认的js Object 10
FUNC napi_create_symbol 创建一个js Symbol 10
FUNC napi_create_typedarray 通过现有的ArrayBuffer创建一个js TypeArray 10
FUNC napi_create_dataview 通过现有的ArrayBuffer创建一个js DataView 10
FUNC napi_create_int32 通过一个C的int32_t数据创建js Number 10
FUNC napi_create_uint32 通过一个C的uint32_t数据创建js Number 10
FUNC napi_create_int64 通过一个C的int64_t数据创建js Number 10
FUNC napi_create_double 通过一个C的double数据创建js Number 10
FUNC napi_create_string_latin1 通过ISO-8859-1编码的C字符串数据创建js String 10
FUNC napi_create_string_utf8 通过UTF8编码的C字符串数据创建js String 10
FUNC napi_create_string_utf16 通过UTF16编码的C字符串数据创建js String 10
FUNC napi_get_array_length 获取array的length。 10
FUNC napi_get_arraybuffer_info 获取ArrayBuffer的底层data buffer及其长度。 10
FUNC napi_get_prototype 获取给定js Objectprototype 10
FUNC napi_get_typedarray_info 获取给定TypedArray的各种属性。 10
FUNC napi_get_dataview_info 获取给定DataView的各种属性。 10
FUNC napi_get_value_bool 获取给定js Boolean对应的C bool值。 10
FUNC napi_get_value_double 获取给定js Number对应的C double值。 10
FUNC napi_get_value_external 获取先前通过napi_create_external()传递的外部数据指针。 10
FUNC napi_get_value_int32 获取给定js Number对应的C int32值。 10
FUNC napi_get_value_int64 获取给定js Number对应的C int64值。 10
FUNC napi_get_value_string_latin1 获取给定js value对应的ISO-8859-1编码的字符串。 10
FUNC napi_get_value_string_utf8 获取给定js value对应的UTF8编码的字符串。 10
FUNC napi_get_value_string_utf16 获取给定js value对应的UTF16编码的字符串。 10
FUNC napi_get_value_uint32 获取给定js Number对应的C uint32值。 10
FUNC napi_get_boolean 根据给定的C boolean值,获取js bool对象。 10
FUNC napi_get_global 获取global对象。 10
FUNC napi_get_null 获取null对象。 10
FUNC napi_get_undefined 获取undefined对象。 10
FUNC napi_coerce_to_bool 将给定的js value强转成js Boolean 10
FUNC napi_coerce_to_number 将给定的js value强转成js Number 10
FUNC napi_coerce_to_object 将给定的js value强转成js Object 10
FUNC napi_coerce_to_string 将给定的js value强转成js String 10
FUNC napi_typeof 获取给定js value的js type。 10
FUNC napi_instanceof 判断给定object是否为给定constructor的实例。 10
FUNC napi_is_array 判断给定js value是否为array。 10
FUNC napi_is_arraybuffer 判断给定js value是否为ArrayBuffer 10
FUNC napi_is_typedarray 判断给定js value是否表示一个TypedArray 10
FUNC napi_is_dataview 判断给定js value是否表示一个DataView 10
FUNC napi_is_date 判断给定js value是否为js Date对象。 10
FUNC napi_strict_equals 判断给定的两个js value是否严格相等。 10
FUNC napi_get_property_names 以字符串数组的形式获取对象的可枚举属性的名称。 10
FUNC napi_set_property 对给定Object设置属性。 10
FUNC napi_get_property 获取给定Object的给定属性。 10
FUNC napi_has_property 判断给定对象中是否存在给定属性。 10
FUNC napi_delete_property 尝试从给定Object中删除给定key属性。 10
FUNC napi_has_own_property 判断给定Object中是否有名为key的own property。 10
FUNC napi_set_named_property 对给定Object设置一个给定名称的属性。 10
FUNC napi_get_named_property 获取给定Object中指定名称的属性。 10
FUNC napi_has_named_property 判断给定Object中是否有给定名称的属性。 10
FUNC napi_set_element 在给定Object的指定索引处,设置元素。 10
FUNC napi_get_element 获取给定Object指定索引处的元素。 10
FUNC napi_has_element 若给定Object的指定索引处拥有属性,获取该元素。 10
FUNC napi_delete_element 尝试删除给定Object的指定索引处的元素。 10
FUNC napi_define_properties 批量的向给定Object中定义属性。 10
FUNC napi_type_tag_object 将tag指针的值与Object关联。 10
FUNC napi_check_object_type_tag 判断给定的tag指针是否被关联到了js Object上。 10
FUNC napi_call_function 在Native方法中调用js function,即native call js。 10
FUNC napi_create_function 创建native方法给js使用,以便于js call native。 10
FUNC napi_get_cb_info 从给定的callback info中获取有关调用的详细信息,如参数和this指针。 10
FUNC napi_get_new_target 获取构造函数调用的new.target 10
FUNC napi_new_instance 通过给定的构造函数,构建一个实例。 10
FUNC napi_define_class 定义与C++类相对应的JavaScript类。 10
FUNC napi_wrap 在js object上绑定一个native对象实例。 10
FUNC napi_unwrap 从js object上获取先前绑定的native对象实例。 10
FUNC napi_remove_wrap 从js object上获取先前绑定的native对象实例,并解除绑定。 10
FUNC napi_create_async_work 创建一个异步工作对象。 10
FUNC napi_delete_async_work 释放先前创建的异步工作对象。 10
FUNC napi_queue_async_work 将异步工作对象加到队列,由底层去调度执行。 10
FUNC napi_cancel_async_work 取消入队的异步任务。 10
FUNC napi_async_init 创建一个异步资源上下文环境(不支持与async_hook相关能力)。 11
FUNC napi_make_callback 在异步资源上下文环境中回调JS函数(不支持与async_hook相关能力)。 11
FUNC napi_async_destroy 销毁先前创建的异步资源上下文环境(不支持与async_hook相关能力)。 11
FUNC napi_open_callback_scope 创建一个回调作用域(不支持与async_hook相关能力)。 11
FUNC napi_close_callback_scope 关闭先前创建的回调作用域(不支持与async_hook相关能力)。 11
FUNC napi_get_node_version 获取node的版本信息。 10
FUNC napi_get_version 获取Node运行时支持的最高 N-API 版本。 10
FUNC napi_create_promise 创建一个延迟对象和js promise。 10
FUNC napi_resolve_deferred resolve与js promise对象关联的延迟函数。 10
FUNC napi_reject_deferred reject与js promise对象关联的延迟函数。 10
FUNC napi_is_promise 判断给定js value是否为promise对象。 10
FUNC napi_get_uv_event_loop 获取当前libuv loop实例。 10
FUNC napi_create_threadsafe_function 创建线程安全函数。 10
FUNC napi_get_threadsafe_function_context 获取线程安全函数中的context。 10
FUNC napi_call_threadsafe_function 调用线程安全函数。 10
FUNC napi_acquire_threadsafe_function 指示线程安全函数可以开始使用。 10
FUNC napi_release_threadsafe_function 指示线程安全函数将停止使用。 10
FUNC napi_ref_threadsafe_function 指示在主线程上运行的事件循环在线程安全函数被销毁之前不应退出。 10
FUNC napi_unref_threadsafe_function 指示在主线程上运行的事件循环可能会在线程安全函数被销毁之前退出。 10
FUNC napi_create_date 通过一个C的double数据创建js Date 10
FUNC napi_get_date_value 获取给定js Date对应的C double值。 10
FUNC napi_create_bigint_int64 通过一个C的int64数据创建js BigInt 10
FUNC napi_create_bigint_uint64 通过一个C的uint64数据创建js BigInt 10
FUNC napi_create_bigint_words 通过一个C的uint64数组创建单个js BigInt 10
FUNC napi_get_value_bigint_int64 获取给定js BigInt对应的C int64值。 10
FUNC napi_get_value_bigint_uint64 获取给定js BigInt对应的C uint64值。 10
FUNC napi_get_value_bigint_words 获取给定js BigInt对应的信息,包括符号位、64位小端序数组和数组中的元素个数。 10
FUNC napi_create_buffer 创建并获取一个指定大小的js Buffer 10
FUNC napi_create_buffer_copy 创建并获取一个指定大小的js Buffer,并以给定数据进行初始化。 10
FUNC napi_create_external_buffer 创建并获取一个指定大小的js Buffer,并以给定数据进行初始化,该接口可为Buffer附带额外数据。 10
FUNC napi_get_buffer_info 获取js Buffer底层data及其长度。 10
FUNC napi_is_buffer 判断给定js value是否为Buffer对象。 10
FUNC napi_object_freeze 冻结给定的对象。 10
FUNC napi_object_seal 密封给定的对象。 10
FUNC napi_get_all_property_names 获取一个数组,其中包含此对象过滤后的属性名称。 10
FUNC napi_detach_arraybuffer 分离给定ArrayBuffer的底层数据。 10
FUNC napi_is_detached_arraybuffer 判断给定的ArrayBuffer是否已被分离过。 10
FUNC napi_run_script 将给定对象作为js代码运行。当前接口实际为空实现,可使用系统拓展接口napi_run_script_path接口,提升安全性。 10
FUNC napi_set_instance_data 绑定与当前运行的环境相关联的数据项。 11
FUNC napi_get_instance_data 检索与当前运行的环境相关联的数据项。 11
FUNC napi_add_env_cleanup_hook 注册环境清理钩子函数。 11
FUNC napi_remove_env_cleanup_hook 取消环境清理钩子函数。 11
FUNC napi_add_async_cleanup_hook 注册清理异步钩子函数。 11
FUNC napi_remove_async_cleanup_hook 取消清理异步钩子函数。 11
FUNC node_api_get_module_file_name 用于获取加载项加载位置的绝对路径。 11
FUNC napi_add_finalizer 当js Object中的对象被垃圾回收时调用注册的napi_finalize回调。 11
FUNC napi_fatal_exception 向js抛出 UncaughtException 12

已导出符号列表与标准库对应符号的差异

napi_throw_error

返回:

  • 当code为空指针时,标准库会返回napi_invalid_arg,而OpenHarmony中未做判断。

  • 该导出接口允许code属性设置失败。

napi_throw_type_error

返回:

  • 当code为空指针时,标准库会返回napi_invalid_arg,而OpenHarmony中未做判断。

  • 该导出接口允许code属性设置失败。

napi_throw_range_error

返回:

  • 当code为空指针时,标准库会返回napi_invalid_arg,而OpenHarmony中未做判断。

  • 该导出接口允许code属性设置失败。

napi_create_error

参数:

  • code: 该导出接口支持String或Number类型。

返回:

  • 当code类型不匹配时,该导出接口返回napi_invalid_arg。

  • 该导出接口允许code属性设置失败。

napi_create_type_error

参数:

  • code: 该导出接口支持String或Number类型。

返回:

  • 当code类型不匹配时,该导出接口返回napi_invalid_arg。

  • 该导出接口允许code属性设置失败。

  • OpenHarmony中创建的错误类型为Error。

napi_create_range_error

参数:

  • code: OpenHarmony中支持String或Number类型。

返回:

  • 当code类型不匹配时,该导出接口返回napi_invalid_arg。

  • 该导出接口允许code属性设置失败。

  • OpenHarmony中创建的错误类型为Error。

napi_create_reference

参数:

  • value: 标准库中仅支持Object、Function、Symbol类型,而该导出接口对value的类型没有限制。

napi_delete_reference

说明:

  • 在OpenHarmony中,如果创建强引用时注册了napi_finalize回调函数,调用该接口的时候会触发该napi_finalize回调。

napi_create_symbol

返回:

  • 当入参description不为空且不是String对象时,该导出接口返回napi_invalid_arg。

napi_create_typedarray

返回:

  • 当入参arraybuffer不为空且不为ArrayBuffer对象时,该导出接口返回napi_arraybuffer_expected。

napi_create_dataview

返回:

  • 当入参arraybuffer不为空且不为ArrayBuffer对象时,该导出接口返回napi_arraybuffer_expected。

  • 如果byte_offset与byte_length的和大于arraybuffer的大小,该导出接口将会抛出RangeError异常,并返回napi_pending_exception。

napi_get_typedarray_info

参数:

返回:

  • 标准库接口中出参length返回typedarray的元素数量,而OpenHarmony的该导出接口返回typedarray中元素的字节长度。

napi_coerce_to_object

返回:

  • 当value为undefined或null时,该导出接口返回napi_ok,出参result为undefined。

napi_instanceof

返回:

  • 当参数object不是Object对象时,该导出接口直接返回napi_object_expected,result不做处理。

  • 当参数constructor不是Function对象时,该导出接口不会抛出异常,接口返回napi_function_expected。

napi_is_typedarray

参数:

napi_get_property_names

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_set_property

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_get_property

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_has_property

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_delete_property

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_has_own_property

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_set_named_property

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_get_named_property

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_has_named_property

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_set_element

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

  • 当设置的index超大的时候,标准库中会直接抛出异常并中断进程,OpenHarmony中会尝试分配内存,若分配失败则不对object进行修改。

napi_get_element

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_has_element

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_delete_element

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_define_properties

返回:

  • 当参数object不是Object或Function对象时,该导出接口返回napi_object_expected。

  • 若在遍历设置属性的过程中触发异常,标准库中会直接将异常抛出,OpenHarmony中会清除异常继续执行。

napi_type_tag_object

返回:

  • 当参数js_object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_check_object_type_tag

返回:

  • 当参数js_object不是Object或Function对象时,该导出接口返回napi_object_expected。

napi_call_function

返回:

  • 该导出接口不会去校验参数recv是否为nullptr。

  • 当参数func不是Function对象时,该导出接口返回napi_function_expected。

napi_new_instance

返回:

  • 当参数constructor不是Function对象时,该导出接口返回napi_function_expected。

napi_define_class

返回:

  • 当length不为NAPI_AUTO_LENGTH且大于INT_MAX时,该导出接口返回napi_object_expected。

napi_wrap

参数:

  • finalize_cb: 标准库允许为空, OpenHarmony在该参数为空时,返回napi_invalid_arg。
  • result: 标准库返回弱引用, OpenHarmony在result不为空时返回强引用。

返回:

  • 参数js_object不为Object或Function对象时,该导出接口返回napi_object_expected。

napi_unwrap

返回:

  • 参数js_object不为Object或Function对象时,该导出接口返回napi_object_expected。

napi_remove_wrap

返回:

  • 参数js_object不为Object或Function对象时,该导出接口返回napi_object_expected。

说明:

  • 如果封装中关联有finalize回调,OpenHarmony中该导出接口将在移除封装前调用它。

napi_create_async_work

参数:

  • 该导出接口暂时不支持async_hooks资源管理机制。

  • 该导出接口不会校验入参async_resource_name是否为String类型对象,入参async_resource_name推荐传入String对象,用于描述创建的异步工作对象。入参async_resource_name为String时,trace信息将包含该描述,反之传入非String对象,trace信息将不包含该描述。

  • 由于当前暂不支持async_hooks资源管理机制,入参async_resource暂时也不做处理。

napi_delete_async_work

参数:

  • 该导出接口暂时不支持async_hooks资源管理机制。

napi_queue_async_work

参数:

  • 该导出接口暂时不支持async_hooks资源管理机制。

napi_cancel_async_work

返回:

  • 若因为底层uv导致取消任务失败,标准库会根据失败原因,返回napi_generic_failure或napi_invalid_arg或napi_cancelled,而在OpenHarmony上该导出接口不会去校验uv的返回值,开发者可以根据相关的日志去排查任务是否取消失败。

napi_async_init

说明:

  • OpenHarmony暂不支持async_hooks资源管理机制。目前未实现与async_hooks交互的内容,该接口调用后并不会有async_hooks的相关操作。

napi_make_callback

说明:

  • OpenHarmony暂不支持async_hooks资源管理机制。目前未实现与async_hooks交互的内容,该接口调用后并不会有async_hooks的相关操作。

napi_async_destroy

说明:

  • OpenHarmony暂不支持async_hooks资源管理机制。目前未实现与async_hooks交互的内容,接口调用后并不会有async_hooks的相关操作。

napi_get_node_version

说明:

  • OpenHarmony不需要获取node的版本,故当前该导出接口为空实现。

napi_resolve_deferred

说明:

  • promise的then方法的resolve或者reject回调中出现异常时,如果promise没有catch块,代码会继续执行不会崩溃;如果promise有catch块,则异常会被该catch块捕获。

napi_reject_deferred

说明:

  • promise的then方法的resolve或者reject回调中出现异常时,如果promise没有catch块,代码会继续执行不会崩溃;如果promise有catch块,则异常会被该catch块捕获。

napi_create_threadsafe_function

参数:

  • initial_thread_count: OpenHarmony中上限为128。

  • async_resource: OpenHarmony中不做类型限制。

  • async_resource_name: OpenHarmony中不做类型限制。

  • func: OpenHarmony中不做类型限制。

说明:

  • OpenHarmony中,创建线程安全函数的过程中没有注册cleanup hook方法,如有需要可以调用napi_add_env_cleanup_hook。

napi_call_threadsafe_function

说明:

  • OpenHarmony调用uv_async_send接口前会检查env是否存活。

  • 调用uv_async_send接口失败时,OpenHarmony中会返回napi_generic_failure。

napi_release_threadsafe_function

说明:

  • OpenHarmony调用uv_async_send接口前会检查env是否存活。

  • ThreadCount为0时,OpenHarmony中会返回napi_generic_failure。

napi_ref_threadsafe_function

说明:

  • OpenHarmony中有校验func和env是否为同一ArkTS线程的过程,若不是同一线程则会返回napi_generic_failure。

napi_unref_threadsafe_function

说明:

  • OpenHarmony中有校验func和env是否为同一ArkTS线程的过程,若不是同一线程则会返回napi_generic_failure。

napi_create_date

返回:

  • 当入参正常但date创建失败时,标准库中返回napi_generic_failure,而OpenHarmony中将会抛出异常,并且接口返回napi_pending_exception。

napi_create_bigint_words

返回:

  • 当入参正常但bigInt创建失败时,标准库中返回napi_generic_failure,而OpenHarmony中将会抛出异常,并且接口返回napi_pending_exception。

napi_get_value_bigint_words

返回:

  • 当参数value不是BigInt对象时,OpenHarmony中返回napi_object_expected。

napi_create_buffer

返回:

  • OpenHarmony中创建的buffer类型为ArrayBufferLike。

  • OpenHarmony中,size小于等于0时返回napi_invalid_arg。

  • OpenHarmony中,size大于2097152时返回napi_invalid_arg并打印错误日志。

  • OpenHarmony中,data为nullptr时返回napi_invalid_arg。

  • 标准库中,进入或退出接口前若有异常将直接返回napi_pending_exception,OpenHarmony中没有对此做校验。

napi_create_buffer_copy

返回:

  • OpenHarmony中创建的buffer类型为ArrayBufferLike。

  • OpenHarmony中,length小于等于0时返回napi_invalid_arg。

  • OpenHarmony中,length大于2097152时返回napi_invalid_arg并打印错误日志。

  • OpenHarmony中,data为nullptr时返回napi_invalid_arg。

  • 标准库中,进入或退出接口前若有异常将直接返回napi_pending_exception,OpenHarmony中没有对此做校验。

napi_create_external_buffer

返回:

  • OpenHarmony中创建的buffer类型为ArrayBufferLike。

  • OpenHarmony中,length小于等于0时返回napi_invalid_arg。

  • OpenHarmony中,length大于2097152时返回napi_invalid_arg并打印错误日志。

  • 标准库中,因未知原因导致创建失败时将返回napi_generic_failure,OpenHarmony中返回napi_pending_exception。

napi_get_buffer_info

返回:

  • OpenHarmony会对value是否属于buffer进行判断,若不属于则返回napi_arraybuffer_expected。

napi_detach_arraybuffer

返回:

  • 当入参arraybuffer不为Object对象时,该导出接口返回napi_object_expected;当arraybuffer是Object对象但不为ArrayBuffer对象时,该导出接口返回napi_invalid_arg。

napi_add_env_cleanup_hook

说明:

  • data已注册到env中时,OpenHarmony仅打印异常日志。

napi_add_finalizer

返回:

  • 入参js_object不是Object对象时,OpenHarmony中该导出接口返回napi_object_expected。

说明:

  • OpenHarmony中,当强引用delete时直接进行回调,无需等到对象析构。

  • 回调主动抛出异常时,OpenHarmony会触发JSCrash。

说明:

  • 标准库中返回弱引用, OpenHarmony在result不为空时返回强引用。

napi_fatal_exception

参数:

  • err: OpenHarmony中仅支持Error类型,类型不匹配将返回napi_invalid_arg。

napi_get_uv_event_loop

返回:

  • 参数env不是有效的napi_env(例如此env已被释放)时,该导出接口返回napi_generic_failure。

napi_create_array_with_length

返回:

  • 当length数值过大时,标准库中会直接抛出异常并中断进程,OpenHarmony中会尝试分配内存,若分配失败则抛出异常并返回长度为0的array。

napi_create_arraybuffer

返回:

  • 当length数值过大时,标准库中会直接抛出异常并中断进程,OpenHarmony中会尝试分配内存,若分配失败则抛出异常并返回undefined。

未从Node-API组件标准库中导出的符号列表

符号类型 符号名 说明
FUNC napi_adjust_external_memory 调整js Object持有的外部内存。

Node-API组件扩展的符号列表

符号类型 符号名 说明 起始支持API版本
FUNC napi_queue_async_work_with_qos 将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。 10
FUNC napi_run_script_path 运行abc文件。 10
FUNC napi_load_module 将abc文件作为模块加载,返回模块的命名空间。 11
FUNC napi_create_object_with_properties 使用给定的napi_property_descriptor创建js Object。descriptor的键名必须为 string,且不可转为number。 11
FUNC napi_create_object_with_named_properties 使用给定的napi_value和键名创建js Object。键名必须为 string,且不可转为number。 11
FUNC napi_coerce_to_native_binding_object 强制将js Object和Native对象绑定。 11
FUNC napi_create_ark_runtime 创建基础运行时环境。 12
FUNC napi_destroy_ark_runtime 销毁基础运行时环境。 12
FUNC napi_run_event_loop 触发底层的事件循环。 12
FUNC napi_stop_event_loop 停止底层的事件循环。 12
FUNC napi_load_module_with_info 将abc文件作为模块加载,返回模块的命名空间。可在新创建的ArkTS基础运行时环境中使用。 12
FUNC napi_serialize 将ArkTS对象转换为native数据。 12
FUNC napi_deserialize 将native数据转为ArkTS对象。 12
FUNC napi_delete_serialization_data 删除序列化数据。 12
FUNC napi_call_threadsafe_function_with_priority 将指定优先级和入队方式的任务投递到ArkTS主线程。 12
FUNC napi_is_sendable 判断给定JS value是否是Sendable的。 12
FUNC napi_define_sendable_class 创建一个Sendable类。 12
FUNC napi_create_sendable_object_with_properties 使用给定的napi_property_descriptor创建一个Sendable对象。 12
FUNC napi_create_sendable_array 创建一个Sendable数组。 12
FUNC napi_create_sendable_array_with_length 创建一个指定长度的Sendable数组。 12
FUNC napi_create_sendable_arraybuffer 创建一个Sendable ArrayBuffer。 12
FUNC napi_create_sendable_typedarray 创建一个Sendable TypedArray。 12
FUNC napi_wrap_sendable 包裹一个native实例到ArkTS对象中。 12
FUNC napi_wrap_sendable_with_size 包裹一个native实例到ArkTS对象中并指定大小。 12
FUNC napi_unwrap_sendable 获取ArkTS对象包裹的native实例。 12
FUNC napi_remove_wrap_sendable 移除并获取ArkTS对象包裹的native实例,移除后回调将不再触发,需手动delete释放内存。 12
FUNC napi_wrap_enhance 在ArkTS对象上绑定一个Node-API模块对象实例并指定实例大小,开发者可以指定绑定的回调函数是否异步执行(若异步则需线程安全)。 18
FUNC napi_create_ark_context 创建一个新的运行时上下文环境。 20
FUNC napi_switch_ark_context 切换到指定的运行时上下文环境。 20
FUNC napi_destroy_ark_context 销毁通过接口napi_create_ark_context创建的一个上下文环境。 20

说明:

有关Sendable特性的介绍,详见Sendable开发指导

napi_qos_t

typedef enum {
    napi_qos_background = 0,      // 低等级,用户不可见任务,例如数据同步、备份。
    napi_qos_utility = 1,         // 中低等级,不需要立即看到响应效果的任务,例如下载或导入数据。
    napi_qos_default = 2,         // 默认
    napi_qos_user_initiated = 3,  // 高等级,用户触发并且可见进展,例如打开文档。
} napi_qos_t;

描述: 表示QoS的枚举值,QoS决定了线程调度的优先级。

napi_event_mode

typedef enum {
    napi_event_mode_default = 0,  // 阻塞式的运行底层事件循环,直到循环中没有任何任务时退出事件循环。
    napi_event_mode_nowait = 1,   // 非阻塞式的运行底层事件循环,尝试去处理一个任务,处理完之后退出事件循环;如果事件循环中没有任务,立刻退出事件循环。
} napi_event_mode;

描述: 用于运行事件循环的事件模式。

napi_queue_async_work_with_qos

napi_status napi_queue_async_work_with_qos(napi_env env,
                                           napi_async_work work,
                                           napi_qos_t qos);

描述:

将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] work: 一个表示异步工作项的对象。这个对象通常是通过napi_create_async_work函数创建的。

  • [in] qos: 决定了线程调度的优先级。

返回:

如果API成功,则返回napi_ok。

napi_run_script_path

napi_status napi_run_script_path(napi_env env,
                                 const char* abcPath,
                                 napi_value* result);

描述:

运行指定abc文件。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] abcPath: 要运行的脚本的JavaScript路径。这是一个字符串,指定了要运行的脚本文件的位置。

  • [out] result: 一个指向napi_value类型的指针,用于存储运行脚本的结果。

返回:

如果API成功,则返回napi_ok。

napi_load_module

napi_status napi_load_module(napi_env env,
                             const char* path,
                             napi_value* result);

描述:

加载系统模块或开发者自定义的模块,返回模块的命名空间。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] path: 要加载的系统模块的名称或开发者自定义模块的路径。

  • [out] result: 一个指向napi_value类型的指针,用于存储加载模块的结果。

返回:

如果API成功,则返回napi_ok。

napi_create_object_with_properties

napi_status napi_create_object_with_properties(napi_env env,
                                               napi_value* result,
                                               size_t property_count,
                                               const napi_property_descriptor* properties);

描述:

属性描述符napi_property_descriptor用于描述一个属性,它包括属性的名称获取和设置方法、属性特性等信息。通过传入这些描述符,可以在创建对象时就定义属性。

使用给定的napi_property_descriptor创建js Object。descriptor的键名必须为string,且不可转为number。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [out] result: 一个指向napi_value类型的指针,用于存储创建的对象。

  • [in] property_count: 要添加到对象中的属性的数量。

  • [in] properties: 一个指向napi_property_descriptor数组的指针,描述了要添加到对象中的属性的信息。

返回:

如果API成功,则返回napi_ok。

napi_create_object_with_named_properties

napi_status napi_create_object_with_named_properties(napi_env env,
                                                     napi_value* result,
                                                     size_t property_count,
                                                     const char** keys,
                                                     const napi_value* values);

描述:

使用给定的napi_value和键名创建js Object。键名必须为string,且不可转为number。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [out] result: 一个指向napi_value类型的指针,用于存储创建的对象。

  • [in] property_count: 要添加到对象中的属性的数量。

  • [in] keys: 一个指向const char*数组的指针,表示属性的名称。

  • [in] values: 一个指向napi_value数组的指针,表示属性的值,与属性名称一一对应。

返回:

如果API成功,则返回napi_ok。

napi_coerce_to_native_binding_object

napi_status napi_coerce_to_native_binding_object(napi_env env,
                                                 napi_value js_object,
                                                 napi_native_binding_detach_callback detach_cb,
                                                 napi_native_binding_attach_callback attach_cb,
                                                 void* native_object,
                                                 void* hint);

描述:

用于给JS Object绑定回调和回调所需的参数,转成携带Native信息的JS Object。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] js_object: 要转换的JavaScript对象。

  • [in] detach_cb: 解绑回调,一般在序列化时调用,可在对象解绑时执行一些清理操作。

  • [in] attach_cb: 绑定回调,一般在序列化时调用。

  • [in] native_object: 需要传递给回调的参数,不能为空。

  • [in] hint: 一个指针,可以用于传递附加的信息给回调函数。

返回:

如果API成功,则返回napi_ok。

napi_create_ark_runtime

napi_status napi_create_ark_runtime(napi_env *env)

描述:

创建基础运行时环境,一个进程最多创建64个,并满足与Worker创建的子线程总数不超过80个。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

返回:

如果API成功,则返回napi_ok。

napi_destroy_ark_runtime

napi_status napi_destroy_ark_runtime(napi_env *env)

描述:

销毁基础运行时环境。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

返回:

如果API成功,则返回napi_ok。

napi_run_event_loop

napi_status napi_run_event_loop(napi_env env, napi_event_mode mode)

描述:

触发底层的事件循环。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。
  • [in] mode: 用于运行事件循环的事件模式。

返回:

如果API成功,则返回napi_ok。

napi_stop_event_loop

napi_status napi_stop_event_loop(napi_env env)

描述:

停止底层的事件循环。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

返回:

如果API成功,则返回napi_ok。

napi_load_module_with_info

napi_status napi_load_module_with_info(napi_env env,
                                       const char* path,
                                       const char* module_info,
                                       napi_value* result)

描述:

将abc文件作为模块加载,返回模块的命名空间。可在新创建的ArkTS基础运行时环境中使用。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] path: 要加载的模块的路径。

  • [in] module_info: 模块信息。这是一个包含模块信息字符串。模块信息可以用于指定模块的版本、作者、描述等详细信息。

  • [out] result: 指向napi_value的指针,用于接收模块的结果。

返回:

如果API成功,则返回napi_ok。

napi_serialize

napi_status napi_serialize(napi_env env,
                           napi_value object,
                           napi_value transfer_list,
                           napi_value clone_list,
                           void** result)

描述:

将ArkTS对象转换为native数据。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] object: 要序列化的JavaScript对象。

  • [in] transfer_list: 传输列表,包含需要在序列化过程中转移的JavaScript对象。

  • [in] clone_list: 克隆列表,包含需要在序列化过程中克隆的JavaScript对象。

  • [out] result: 用于接收序列化结果的指针。在调用完成后,指向实际结果的指针会存储在此位置。

返回:

如果API成功,则返回napi_ok。

napi_deserialize

napi_status napi_deserialize(napi_env env, void* buffer, napi_value* object)

描述:

将native数据转为ArkTS对象。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] buffer: 指向包含二进制数据的指针。这些二进制数据需要被反序列化为JavaScript对象。

  • [out] object: 用于接收反序列化后的JavaScript对象。

返回:

如果API成功,则返回napi_ok。

napi_delete_serialization_data

napi_status napi_delete_serialization_data(napi_env env, void* buffer)

描述:

删除序列化数据。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] buffer: 指向包含序列化数据的内存缓冲区的指针。这些数据在序列化完成后不再需要,并且可以通过调用此函数来释放相应的内存。

返回:

如果API成功,则返回napi_ok。

napi_call_threadsafe_function_with_priority

napi_status napi_call_threadsafe_function_with_priority(napi_threadsafe_function func,
                                                        void *data,
                                                        napi_task_priority priority,
                                                        bool isTail)

描述:

将指定优先级和入队方式的任务投递到ArkTS主线程。

参数:

  • [in] func: 线程安全函数对象,在创建线程安全函数时返回。

  • [in] data: 传递给 JavaScript 回调函数的参数数据。

  • [in] priority: 指定调用 JavaScript 回调函数的任务优先级。

  • [in] isTail: 一个布尔值,指示调用是否应该排队等待在事件循环的尾部执行。如果为 true,则调用将在事件循环的尾部执行;如果为 false,则调用将立即执行,不会排队等待。

返回:

如果API成功,则返回napi_ok。

napi_is_sendable

napi_status napi_is_sendable(napi_env env, napi_value value, bool* result)

描述:

判断给定JS value是否是Sendable的。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] value: 一个napi_value类型的参数,是需要判断的值。

  • [out] result: 一个bool类型的指针,用于存储判断结果。

返回:

如果API成功,则返回napi_ok。

napi_define_sendable_class

napi_status napi_define_sendable_class(napi_env env,
                                       const char* utf8name,
                                       size_t length,
                                       napi_callback constructor,
                                       void* data,
                                       size_t property_count,
                                       const napi_property_descriptor* properties,
                                       napi_value parent,
                                       napi_value* result)


描述:

创建一个Sendable类。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] utf8name:一个const char*类型的参数,表示类的名称。

  • [in] length:一个size_t类型的参数,表示类名称的字节数。

  • [in] constructor:一个napi_callback类型的参数,表示类的构造函数。

  • [in] data:[可选]一个void*类型的参数,表示构造函数的附加数据。

  • [in] property_count:一个size_t类型的参数,表示类的属性数量。

  • [in] properties:[可选]一个const napi_property_descriptor*类型的参数,表示类的属性描述符数组。

  • [in] parent:[可选]一个napi_value类型的参数,表示父类。

  • [out] result:一个napi_value类型的指针,用于存储创建的对象。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_object_with_properties

napi_status napi_create_sendable_object_with_properties(napi_env env,
                                                        size_t property_count,
                                                        const napi_property_descriptor* properties,
                                                        napi_value* result)

描述:

使用给定的napi_property_descriptor创建一个Sendable对象。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] property_count:一个size_t类型的参数,表示属性数量。

  • [in] properties:一个const napi_property_descriptor*类型的参数,表示属性描述符数组。

  • [out] result:一个napi_value类型的指针,用于存储创建的对象。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_array

napi_status napi_create_sendable_array(napi_env env, napi_value* result)

描述:

创建一个Sendable数组。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [out] result:一个napi_value类型的指针,用于存储创建的数组。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_array_with_length

napi_status napi_create_sendable_array_with_length(napi_env env, size_t length, napi_value* result)

描述:

创建一个指定长度的Sendable数组。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] length:一个size_t类型的参数,表示数组的长度。

  • [out] result:一个napi_value类型的指针,用于存储创建的数组。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_arraybuffer

napi_status napi_create_sendable_arraybuffer(napi_env env, size_t byte_length, void** data, napi_value* result)

描述:

创建一个Sendable ArrayBuffer。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] byte_length:要创建的ArrayBuffer的大小。

  • [in] data:指向底层字节缓冲区的指针。

  • [out] result:一个napi_value类型的指针,用于存储创建的ArrayBuffer。

返回:

如果API成功,则返回napi_ok。

napi_create_sendable_typedarray

napi_status napi_create_sendable_typedarray(napi_env env,
                                            napi_typedarray_type type,
                                            size_t length,
                                            napi_value arraybuffer,
                                            size_t byte_offset,
                                            napi_value* result);

描述:

创建一个Sendable TypedArray。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] type:TypedArray 的类型。

  • [in] length:TypedArray 的长度。

  • [in] arraybuffer:一个 ArrayBuffer 实例。

  • [in] byte_offset:ArrayBuffer 的偏移量。

  • [out] result:一个napi_value类型的指针,用于存储创建的TypedArray。

返回:

如果API成功,则返回napi_ok。

napi_wrap_sendable

napi_status napi_wrap_sendable(napi_env env,
                               napi_value js_object,
                               void* native_object,
                               napi_finalize finalize_cb,
                               void* finalize_hint);

描述:

包裹一个native实例到ArkTS对象中。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] js_object:ArkTS对象。

  • [in] native_object:将被包裹在ArkTS对象中的native实例。

  • [in] napi_finalize:[可选]ArkTS对象被销毁时调用的回调函数。

  • [in] finalize_hint:[可选]上下文提示,会传递给回调函数。

返回:

如果API成功,则返回napi_ok。

napi_wrap_sendable_with_size

napi_status napi_wrap_sendable_with_size(napi_env env,
                                         napi_value js_object,
                                         void* native_object,
                                         napi_finalize finalize_cb,
                                         void* finalize_hint,
                                         size_t native_binding_size);

描述:

包装一个native实例到ArkTS对象中并指定大小。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] js_object:ArkTS对象。

  • [in] native_object:将被包裹在ArkTS对象中的native实例。

  • [in] napi_finalize:[可选]ArkTS对象被销毁时调用的回调函数。

  • [in] finalize_hint:[可选]上下文提示,会传递给回调函数。

  • [in] native_binding_size:[可选]绑定的native实例的大小。

返回:

如果API成功,则返回napi_ok。

napi_unwrap_sendable

napi_status napi_unwrap_sendable(napi_env env, napi_value js_object, void** result)

描述:

获取ArkTS对象包装的native实例。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] js_object:ArkTS对象。

  • [out] result:包裹在ArkTS对象中的native实例。

返回:

如果API成功,则返回napi_ok。

napi_remove_wrap_sendable

napi_status napi_remove_wrap_sendable(napi_env env, napi_value js_object, void** result)

描述:

移除并获取ArkTS对象包装的native实例,移除后回调将不再触发,需手动delete释放内存。

参数:

  • [in] env: Node-API的环境对象,表示当前的执行环境。

  • [in] js_object:ArkTS对象。

  • [out] result:包裹在ArkTS对象中的native实例。

返回:

如果API成功,则返回napi_ok。

napi_wrap_enhance

napi_status napi_wrap_enhance(napi_env env,
                              napi_value js_object,
                              void* native_object,
                              napi_finalize finalize_cb,
                              bool async_finalizer,
                              void* finalize_hint,
                              size_t native_binding_size,
                              napi_ref* result);

描述:

在ArkTS对象上绑定一个Node-API模块对象实例并指定实例大小,开发者可以指定绑定的回调函数是否异步执行,如果异步执行,则回调函数必须是线程安全的。

参数:

  • [in] env:Node-API的环境对象,表示当前的执行环境。

  • [in] js_object:ArkTS对象。

  • [in] native_object:将被包裹在ArkTS对象中的native实例。

  • [in] finalize_cb:[可选]ArkTS对象被销毁时调用的回调函数,详情请参见napi_finalize回调函数说明

  • [in] async_finalizer:一个布尔值,表示ArkTS对象被销毁时调用的回调函数是否异步执行。如果为true,表示异步执行,需确保线程安全;如果为false,则表示同步执行。

  • [in] finalize_hint:[可选]上下文提示,会传递给回调函数。

  • [in] native_binding_size:[可选]绑定的native实例的大小。

  • [out] result:[可选]接收ArkTS对象引用的指针。

返回:

  • napi_ok:如果API成功,则返回napi_ok。

  • napi_invalid_arg:参数env、js_object或native_object为空时返回。

  • napi_object_expected:参数js_object不是ArkTs对象或函数时返回。

  • napi_pending_exception:如果有未捕获的异常或执行过程中发生异常时返回。

napi_finalize回调函数说明

typedef void (*napi_finalize)(napi_env env,
                              void* finalize_data,
                              void* finalize_hint);

描述:

用于定义在Node-API对象生命周期结束时触发的回调函数。

参数:

  • [in] env:Node-API的环境对象,表示当前的执行环境。

  • [in] finalize_data:指向需要清理的用户数据的指针。

  • [in] finalize_hint:上下文提示,用于辅助清理过程。

返回:

  • void:此回调函数无返回值。

你可能感兴趣的鸿蒙文章

harmony 鸿蒙Native API标准库

harmony 鸿蒙VkExternalFormatOHOS

harmony 鸿蒙VkImportNativeBufferInfoOHOS

harmony 鸿蒙VkMemoryGetNativeBufferInfoOHOS

harmony 鸿蒙VkNativeBufferFormatPropertiesOHOS

harmony 鸿蒙VkNativeBufferPropertiesOHOS

harmony 鸿蒙VkNativeBufferUsageOHOS

harmony 鸿蒙VkSurfaceCreateInfoOHOS

harmony 鸿蒙Vulkan模块

harmony 鸿蒙标准C++库

0  赞