1e41f4b71Sopenharmony_ci# Node-API
2e41f4b71Sopenharmony_ci
3e41f4b71Sopenharmony_ci## 简介
4e41f4b71Sopenharmony_ci
5e41f4b71Sopenharmony_ciNode-API是用于封装JavaScript能力为Native插件的API,独立于底层JavaScript,并作为Node.js的一部分。
6e41f4b71Sopenharmony_ci
7e41f4b71Sopenharmony_ci## 支持的能力
8e41f4b71Sopenharmony_ci
9e41f4b71Sopenharmony_ciNode-API可以去除底层的JavaScript引擎的差异,提供一套稳定的接口。
10e41f4b71Sopenharmony_ci
11e41f4b71Sopenharmony_ciOpenHarmony的Node-API组件对Node-API的接口进行了重新实现,底层对接了ArkJS等引擎。当前支持Node-API标准库中的部分接口。
12e41f4b71Sopenharmony_ci
13e41f4b71Sopenharmony_ci## 引入Node-API能力
14e41f4b71Sopenharmony_ci
15e41f4b71Sopenharmony_ci如果开发者需要使用Node-API相关功能,首先请添加头文件:
16e41f4b71Sopenharmony_ci
17e41f4b71Sopenharmony_ci```cpp
18e41f4b71Sopenharmony_ci#include <napi/native_api.h>
19e41f4b71Sopenharmony_ci```
20e41f4b71Sopenharmony_ci
21e41f4b71Sopenharmony_ci其次在CMakeLists.txt中添加以下动态链接库:
22e41f4b71Sopenharmony_ci
23e41f4b71Sopenharmony_ci```
24e41f4b71Sopenharmony_cilibace_napi.z.so
25e41f4b71Sopenharmony_ci```
26e41f4b71Sopenharmony_ci
27e41f4b71Sopenharmony_ci## 已从Node-API组件标准库中导出的符号列表
28e41f4b71Sopenharmony_ci
29e41f4b71Sopenharmony_ci从Node-API标准库导出的接口,其使用方法及行为基于[Node.js](https://nodejs.org/docs/latest-v8.x/api/n-api.html),并进行了部分[能力拓展](#node-api组件扩展的符号列表)。
30e41f4b71Sopenharmony_ci
31e41f4b71Sopenharmony_ci|符号类型|符号名|说明|起始支持API版本|
32e41f4b71Sopenharmony_ci| --- | --- | --- | --- |
33e41f4b71Sopenharmony_ci|FUNC|napi_module_register|napi native模块注册接口。|10|
34e41f4b71Sopenharmony_ci|FUNC|napi_get_last_error_info|获取`napi_extended_error_info`结构体,其中包含最近一次出现的error信息。|10|
35e41f4b71Sopenharmony_ci|FUNC|napi_throw|抛出一个js value。|10|
36e41f4b71Sopenharmony_ci|FUNC|napi_throw_error|抛出一个带文本信息的js `Error`。|10|
37e41f4b71Sopenharmony_ci|FUNC|napi_throw_type_error|抛出一个带文本信息的js `TypeError`。|10|
38e41f4b71Sopenharmony_ci|FUNC|napi_throw_range_error|抛出一个带文本信息的js `RangeError`。|10|
39e41f4b71Sopenharmony_ci|FUNC|napi_is_error|判断`napi_value`是否表示为一个error对象。|10|
40e41f4b71Sopenharmony_ci|FUNC|napi_create_error|创建并获取一个带文本信息的js `Error`。|10|
41e41f4b71Sopenharmony_ci|FUNC|napi_create_type_error|创建并获取一个带文本信息的js `TypeError`。|10|
42e41f4b71Sopenharmony_ci|FUNC|napi_create_range_error|创建并获取一个带文本信息的js `RangeError`。|10|
43e41f4b71Sopenharmony_ci|FUNC|napi_get_and_clear_last_exception|获取并清除最近一次出现的异常。|10|
44e41f4b71Sopenharmony_ci|FUNC|napi_is_exception_pending|判断是否出现了异常。|10|
45e41f4b71Sopenharmony_ci|FUNC|napi_fatal_error|引发致命错误以立即终止进程。|10|
46e41f4b71Sopenharmony_ci|FUNC|napi_open_handle_scope|创建一个上下文环境使用。|10|
47e41f4b71Sopenharmony_ci|FUNC|napi_close_handle_scope|关闭传入的上下文环境,关闭后,全部在其中声明的引用都将被关闭。|10|
48e41f4b71Sopenharmony_ci|FUNC|napi_open_escapable_handle_scope|创建出一个可逃逸的handel scope,可将范围内声明的值返回到父作用域。|10|
49e41f4b71Sopenharmony_ci|FUNC|napi_close_escapable_handle_scope|关闭传入的可逃逸的handel scope。|10|
50e41f4b71Sopenharmony_ci|FUNC|napi_escape_handle|提升传入的js object的生命周期到其父作用域。|10|
51e41f4b71Sopenharmony_ci|FUNC|napi_create_reference|为`Object`创建一个reference,以延长其生命周期。调用者需要自己管理reference生命周期。|10|
52e41f4b71Sopenharmony_ci|FUNC|napi_delete_reference|删除传入的reference。|10|
53e41f4b71Sopenharmony_ci|FUNC|napi_reference_ref|增加传入的reference的引用计数,并获取该计数。|10|
54e41f4b71Sopenharmony_ci|FUNC|napi_reference_unref|减少传入的reference的引用计数,并获取该计数。|10|
55e41f4b71Sopenharmony_ci|FUNC|napi_get_reference_value|获取与reference相关联的js `Object`。|10|
56e41f4b71Sopenharmony_ci|FUNC|napi_create_array|创建并获取一个js `Array`。|10|
57e41f4b71Sopenharmony_ci|FUNC|napi_create_array_with_length|创建并获取一个指定长度的js `Array`。|10|
58e41f4b71Sopenharmony_ci|FUNC|napi_create_arraybuffer|创建并获取一个指定大小的js `ArrayBuffer`。|10|
59e41f4b71Sopenharmony_ci|FUNC|napi_create_external|分配一个附加有外部数据的js value。|10|
60e41f4b71Sopenharmony_ci|FUNC|napi_create_external_arraybuffer|分配一个附加有外部数据的js `ArrayBuffer`。|10|
61e41f4b71Sopenharmony_ci|FUNC|napi_create_object|创建一个默认的js `Object`。|10|
62e41f4b71Sopenharmony_ci|FUNC|napi_create_symbol|创建一个js `Symbol`。|10|
63e41f4b71Sopenharmony_ci|FUNC|napi_create_typedarray|通过现有的`ArrayBuffer`创建一个js `TypeArray`。|10|
64e41f4b71Sopenharmony_ci|FUNC|napi_create_dataview|通过现有的`ArrayBuffer`创建一个js `DataView`。|10|
65e41f4b71Sopenharmony_ci|FUNC|napi_create_int32|通过一个C的`int32_t`数据创建js `Number`。|10|
66e41f4b71Sopenharmony_ci|FUNC|napi_create_uint32|通过一个C的`uint32_t`数据创建js `Number`。|10|
67e41f4b71Sopenharmony_ci|FUNC|napi_create_int64|通过一个C的`int64_t`数据创建js `Number`。|10|
68e41f4b71Sopenharmony_ci|FUNC|napi_create_double|通过一个C的`double`数据创建js `Number`。|10|
69e41f4b71Sopenharmony_ci|FUNC|napi_create_string_latin1|通过ISO-8859-1编码的C字符串数据创建js `String`。|10|
70e41f4b71Sopenharmony_ci|FUNC|napi_create_string_utf8|通过UTF8编码的C字符串数据创建js `String`。|10|
71e41f4b71Sopenharmony_ci|FUNC|napi_create_string_utf16|通过UTF16编码的C字符串数据创建js `String`。|10|
72e41f4b71Sopenharmony_ci|FUNC|napi_get_array_length|获取array的length。|10|
73e41f4b71Sopenharmony_ci|FUNC|napi_get_arraybuffer_info|获取`ArrayBuffer`的底层data buffer及其长度。|10|
74e41f4b71Sopenharmony_ci|FUNC|napi_get_prototype|获取给定js `Object`的`prototype`。|10|
75e41f4b71Sopenharmony_ci|FUNC|napi_get_typedarray_info|获取给定`TypedArray`的各种属性。|10|
76e41f4b71Sopenharmony_ci|FUNC|napi_get_dataview_info|获取给定`DataView`的各种属性。|10|
77e41f4b71Sopenharmony_ci|FUNC|napi_get_value_bool|获取给定js `Boolean`对应的C bool值。|10|
78e41f4b71Sopenharmony_ci|FUNC|napi_get_value_double|获取给定js `Number`对应的C double值。|10|
79e41f4b71Sopenharmony_ci|FUNC|napi_get_value_external|获取先前通过napi_create_external()传递的外部数据指针。|10|
80e41f4b71Sopenharmony_ci|FUNC|napi_get_value_int32|获取给定js `Number`对应的C int32值。|10|
81e41f4b71Sopenharmony_ci|FUNC|napi_get_value_int64|获取给定js `Number`对应的C int64值。|10|
82e41f4b71Sopenharmony_ci|FUNC|napi_get_value_string_latin1|获取给定js vaule对应的ISO-8859-1编码的字符串。|10|
83e41f4b71Sopenharmony_ci|FUNC|napi_get_value_string_utf8|获取给定js vaule对应的UTF8编码的字符串。|10|
84e41f4b71Sopenharmony_ci|FUNC|napi_get_value_string_utf16|获取给定js vaule对应的UTF16编码的字符串。|10|
85e41f4b71Sopenharmony_ci|FUNC|napi_get_value_uint32|获取给定js `Number`对应的C uint32值。|10|
86e41f4b71Sopenharmony_ci|FUNC|napi_get_boolean|根据给定的C boolean值,获取js bool对象。|10|
87e41f4b71Sopenharmony_ci|FUNC|napi_get_global|获取`global`对象。|10|
88e41f4b71Sopenharmony_ci|FUNC|napi_get_null|获取`null`对象。|10|
89e41f4b71Sopenharmony_ci|FUNC|napi_get_undefined|获取`undefined`对象。|10|
90e41f4b71Sopenharmony_ci|FUNC|napi_coerce_to_bool|将给定的js value强转成js `Boolean`。|10|
91e41f4b71Sopenharmony_ci|FUNC|napi_coerce_to_number|将给定的js value强转成js `Number`。|10|
92e41f4b71Sopenharmony_ci|FUNC|napi_coerce_to_object|将给定的js value强转成js `Object`。|10|
93e41f4b71Sopenharmony_ci|FUNC|napi_coerce_to_string|将给定的js value强转成js `String`。|10|
94e41f4b71Sopenharmony_ci|FUNC|napi_typeof|获取给定js value的js type。|10|
95e41f4b71Sopenharmony_ci|FUNC|napi_instanceof|判断给定object是否为给定constructor的实例。|10|
96e41f4b71Sopenharmony_ci|FUNC|napi_is_array|判断给定js value是否为array。|10|
97e41f4b71Sopenharmony_ci|FUNC|napi_is_arraybuffer|判断给定js value是否为`ArrayBuffer`。|10|
98e41f4b71Sopenharmony_ci|FUNC|napi_is_typedarray|判断给定js value是否表示一个`TypedArray`。|10|
99e41f4b71Sopenharmony_ci|FUNC|napi_is_dataview|判断给定js value是否表示一个`DataView`。|10|
100e41f4b71Sopenharmony_ci|FUNC|napi_is_date|判断给定js value是否为js `Date`对象。|10|
101e41f4b71Sopenharmony_ci|FUNC|napi_strict_equals|判断给定的两个js value是否严格相等。|10|
102e41f4b71Sopenharmony_ci|FUNC|napi_get_property_names|以字符串数组的形式获取对象的可枚举属性的名称。|10|
103e41f4b71Sopenharmony_ci|FUNC|napi_set_property|对给定`Object`设置属性。|10|
104e41f4b71Sopenharmony_ci|FUNC|napi_get_property|获取给定`Object`的给定属性。|10|
105e41f4b71Sopenharmony_ci|FUNC|napi_has_property|判断给定对象中是否存在给定属性。|10|
106e41f4b71Sopenharmony_ci|FUNC|napi_delete_property|尝试从给定`Object`中删除给定`key`属性。|10|
107e41f4b71Sopenharmony_ci|FUNC|napi_has_own_property|判断给定`Object`中是否有名为`key`的own property。|10|
108e41f4b71Sopenharmony_ci|FUNC|napi_set_named_property|对给定`Object`设置一个给定名称的属性。|10|
109e41f4b71Sopenharmony_ci|FUNC|napi_get_named_property|获取给定`Object`中指定名称的属性。|10|
110e41f4b71Sopenharmony_ci|FUNC|napi_has_named_property|判断给定`Object`中是否有给定名称的属性。|10|
111e41f4b71Sopenharmony_ci|FUNC|napi_set_element|在给定`Object`的指定索引处,设置元素。|10|
112e41f4b71Sopenharmony_ci|FUNC|napi_get_element|获取给定`Object`指定索引处的元素。|10|
113e41f4b71Sopenharmony_ci|FUNC|napi_has_element|若给定`Object`的指定索引处拥有属性,获取该元素。|10|
114e41f4b71Sopenharmony_ci|FUNC|napi_delete_element|尝试删除给定`Object`的指定索引处的元素。|10|
115e41f4b71Sopenharmony_ci|FUNC|napi_define_properties|批量的向给定`Object`中定义属性。|10|
116e41f4b71Sopenharmony_ci|FUNC|napi_type_tag_object|将tag指针的值与`Object`关联。|10|
117e41f4b71Sopenharmony_ci|FUNC|napi_check_object_type_tag|判断给定的tag指针是否被关联到了js `Object`上。|10|
118e41f4b71Sopenharmony_ci|FUNC|napi_call_function|在Native方法中调用js function,即native call js。|10|
119e41f4b71Sopenharmony_ci|FUNC|napi_create_function|创建native方法给js使用,以便于js call native。|10|
120e41f4b71Sopenharmony_ci|FUNC|napi_get_cb_info|从给定的callback info中获取有关调用的详细信息,如参数和this指针。|10|
121e41f4b71Sopenharmony_ci|FUNC|napi_get_new_target|获取构造函数调用的`new.target`。|10|
122e41f4b71Sopenharmony_ci|FUNC|napi_new_instance|通过给定的构造函数,构建一个实例。|10|
123e41f4b71Sopenharmony_ci|FUNC|napi_define_class|定义与C++类相对应的JavaScript类。|10|
124e41f4b71Sopenharmony_ci|FUNC|napi_wrap|在js object上绑定一个native对象实例。|10|
125e41f4b71Sopenharmony_ci|FUNC|napi_unwrap|从js object上获取先前绑定的native对象实例。|10|
126e41f4b71Sopenharmony_ci|FUNC|napi_remove_wrap|从js object上获取先前绑定的native对象实例,并解除绑定。|10|
127e41f4b71Sopenharmony_ci|FUNC|napi_create_async_work|创建一个异步工作对象。|10|
128e41f4b71Sopenharmony_ci|FUNC|napi_delete_async_work|释放先前创建的异步工作对象。|10|
129e41f4b71Sopenharmony_ci|FUNC|napi_queue_async_work|将异步工作对象加到队列,由底层去调度执行。|10|
130e41f4b71Sopenharmony_ci|FUNC|napi_cancel_async_work|取消入队的异步任务。|10|
131e41f4b71Sopenharmony_ci|FUNC|napi_async_init|创建一个异步资源上下文环境(不支持与async_hook相关能力)。|11|
132e41f4b71Sopenharmony_ci|FUNC|napi_make_callback|在异步资源上下文环境中回调JS函数(不支持与async_hook相关能力)。|11|
133e41f4b71Sopenharmony_ci|FUNC|napi_async_destroy|销毁先前创建的异步资源上下文环境(不支持与async_hook相关能力)。|11|
134e41f4b71Sopenharmony_ci|FUNC|napi_open_callback_scope|创建一个回调作用域(不支持与async_hook相关能力)。|11|
135e41f4b71Sopenharmony_ci|FUNC|napi_close_callback_scope|关闭先前创建的回调作用域(不支持与async_hook相关能力)。|11|
136e41f4b71Sopenharmony_ci|FUNC|napi_get_node_version|获取node的版本信息。|10|
137e41f4b71Sopenharmony_ci|FUNC|napi_get_version|获取Node运行时支持的最高 N-API 版本。|10|
138e41f4b71Sopenharmony_ci|FUNC|napi_create_promise|创建一个延迟对象和js promise。|10|
139e41f4b71Sopenharmony_ci|FUNC|napi_resolve_deferred|resolve与js promise对象关联的延迟函数。|10|
140e41f4b71Sopenharmony_ci|FUNC|napi_reject_deferred|reject与js promise对象关联的延迟函数。|10|
141e41f4b71Sopenharmony_ci|FUNC|napi_is_promise|判断给定js value是否为promise对象。|10|
142e41f4b71Sopenharmony_ci|FUNC|napi_get_uv_event_loop|获取当前libuv loop实例。|10|
143e41f4b71Sopenharmony_ci|FUNC|napi_create_threadsafe_function|创建线程安全函数。|10|
144e41f4b71Sopenharmony_ci|FUNC|napi_get_threadsafe_function_context|获取线程安全函数中的context。|10|
145e41f4b71Sopenharmony_ci|FUNC|napi_call_threadsafe_function|调用线程安全函数。|10|
146e41f4b71Sopenharmony_ci|FUNC|napi_acquire_threadsafe_function|指示线程安全函数可以开始使用。|10|
147e41f4b71Sopenharmony_ci|FUNC|napi_release_threadsafe_function|指示线程安全函数将停止使用。|10|
148e41f4b71Sopenharmony_ci|FUNC|napi_ref_threadsafe_function|指示在主线程上运行的事件循环在线程安全函数被销毁之前不应退出。|10|
149e41f4b71Sopenharmony_ci|FUNC|napi_unref_threadsafe_function|指示在主线程上运行的事件循环可能会在线程安全函数被销毁之前退出。|10|
150e41f4b71Sopenharmony_ci|FUNC|napi_create_date|通过一个C的`double`数据创建js `Date`。|10|
151e41f4b71Sopenharmony_ci|FUNC|napi_get_date_value|获取给定js `Date`对应的C double值。|10|
152e41f4b71Sopenharmony_ci|FUNC|napi_create_bigint_int64|通过一个C的`int64`数据创建js `BigInt`。|10|
153e41f4b71Sopenharmony_ci|FUNC|napi_create_bigint_uint64|通过一个C的`uint64`数据创建js `BigInt`。|10|
154e41f4b71Sopenharmony_ci|FUNC|napi_create_bigint_words|通过一个C的`uint64`数组创建单个js `BigInt`。|10|
155e41f4b71Sopenharmony_ci|FUNC|napi_get_value_bigint_int64|获取给定js `BigInt`对应的C int64值。|10|
156e41f4b71Sopenharmony_ci|FUNC|napi_get_value_bigint_uint64|获取给定js `BigInt`对应的C uint64值。|10|
157e41f4b71Sopenharmony_ci|FUNC|napi_get_value_bigint_words|获取给定js `BigInt`对应的信息,包括符号位、64位小端序数组和数组中的元素个数。|10|
158e41f4b71Sopenharmony_ci|FUNC|napi_create_buffer|创建并获取一个指定大小的js `Buffer`。|10|
159e41f4b71Sopenharmony_ci|FUNC|napi_create_buffer_copy|创建并获取一个指定大小的js `Buffer`,并以给定数据进行初始化。|10|
160e41f4b71Sopenharmony_ci|FUNC|napi_create_external_buffer|创建并获取一个指定大小的js `Buffer`,并以给定数据进行初始化,该接口可为`Buffer`附带额外数据。|10|
161e41f4b71Sopenharmony_ci|FUNC|napi_get_buffer_info|获取js `Buffer`底层data及其长度。|10|
162e41f4b71Sopenharmony_ci|FUNC|napi_is_buffer|判断给定js value是否为`Buffer`对象。|10|
163e41f4b71Sopenharmony_ci|FUNC|napi_object_freeze|冻结给定的对象。|10|
164e41f4b71Sopenharmony_ci|FUNC|napi_object_seal|密封给定的对象。|10|
165e41f4b71Sopenharmony_ci|FUNC|napi_get_all_property_names|获取一个数组,其中包含此对象过滤后的属性名称。|10|
166e41f4b71Sopenharmony_ci|FUNC|napi_detach_arraybuffer|分离给定`ArrayBuffer`的底层数据。|10|
167e41f4b71Sopenharmony_ci|FUNC|napi_is_detached_arraybuffer|判断给定的`ArrayBuffer`是否已被分离过。|10|
168e41f4b71Sopenharmony_ci|FUNC|napi_run_script|将给定对象作为js代码运行。当前接口实际为空实现,可使用系统拓展接口`napi_run_script_path`接口,提升安全性。|10|
169e41f4b71Sopenharmony_ci|FUNC|napi_set_instance_data|绑定与当前运行的环境相关联的数据项。|11|
170e41f4b71Sopenharmony_ci|FUNC|napi_get_instance_data|检索与当前运行的环境相关联的数据项。|11|
171e41f4b71Sopenharmony_ci|FUNC|napi_add_env_cleanup_hook|注册环境清理钩子函数。|11|
172e41f4b71Sopenharmony_ci|FUNC|napi_remove_env_cleanup_hook|取消环境清理钩子函数。|11|
173e41f4b71Sopenharmony_ci|FUNC|napi_add_async_cleanup_hook|注册清理异步钩子函数。|11|
174e41f4b71Sopenharmony_ci|FUNC|napi_remove_async_cleanup_hook|取消清理异步钩子函数。|11|
175e41f4b71Sopenharmony_ci|FUNC|node_api_get_module_file_name|用于获取加载项加载位置的绝对路径。|11|
176e41f4b71Sopenharmony_ci|FUNC|napi_add_finalizer|当js `Object`中的对象被垃圾回收时调用注册的napi_finalize回调。|11|
177e41f4b71Sopenharmony_ci|FUNC|napi_fatal_exception|向js抛出 `UncaughtException`。|12|
178e41f4b71Sopenharmony_ci
179e41f4b71Sopenharmony_ci## 未从Node-API组件标准库中导出的符号列表
180e41f4b71Sopenharmony_ci
181e41f4b71Sopenharmony_ci|符号类型|符号名|说明|
182e41f4b71Sopenharmony_ci| --- | --- | --- |
183e41f4b71Sopenharmony_ci|FUNC|napi_adjust_external_memory|调整js `Object`持有的外部内存。|
184e41f4b71Sopenharmony_ci
185e41f4b71Sopenharmony_ci## Node-API组件扩展的符号列表
186e41f4b71Sopenharmony_ci
187e41f4b71Sopenharmony_ci|符号类型|符号名|说明|起始支持API版本|
188e41f4b71Sopenharmony_ci| --- | --- | --- | --- |
189e41f4b71Sopenharmony_ci|FUNC|napi_queue_async_work_with_qos|将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。|10|
190e41f4b71Sopenharmony_ci|FUNC|napi_run_script_path|运行abc文件。|10|
191e41f4b71Sopenharmony_ci|FUNC|napi_load_module|将abc文件作为模块加载,返回模块的命名空间。|11|
192e41f4b71Sopenharmony_ci|FUNC|napi_create_object_with_properties|使用给定的napi_property_descriptor创建js `Object`。descriptor的键名必须为 string,且不可转为number。|11|
193e41f4b71Sopenharmony_ci|FUNC|napi_create_object_with_named_properties|使用给定的napi_value和键名创建js `Object`。键名必须为 string,且不可转为number。|11|
194e41f4b71Sopenharmony_ci|FUNC|napi_coerce_to_native_binding_object|强制将js `Object`和Native对象绑定。|11|
195e41f4b71Sopenharmony_ci|FUNC|napi_create_ark_runtime|创建基础运行时环境。|12|
196e41f4b71Sopenharmony_ci|FUNC|napi_destroy_ark_runtime|销毁基础运行时环境。|12|
197e41f4b71Sopenharmony_ci|FUNC|napi_run_event_loop|触发底层的事件循环。|12|
198e41f4b71Sopenharmony_ci|FUNC|napi_stop_event_loop|停止底层的事件循环。|12|
199e41f4b71Sopenharmony_ci|FUNC|napi_load_module_with_info|将abc文件作为模块加载,返回模块的命名空间。可在新创建的ArkTS基础运行时环境中使用。|12|
200e41f4b71Sopenharmony_ci|FUNC|napi_serialize|将ArkTS对象转换为native数据。|12|
201e41f4b71Sopenharmony_ci|FUNC|napi_deserialize|将native数据转为ArkTS对象。|12|
202e41f4b71Sopenharmony_ci|FUNC|napi_delete_serialization_data|删除序列化数据。|12|
203e41f4b71Sopenharmony_ci|FUNC|napi_call_threadsafe_function_with_priority|将指定优先级和入队方式的任务投递到ArkTS主线程。|12|
204e41f4b71Sopenharmony_ci|FUNC|napi_is_sendable|判断给定JS value是否是Sendable的。|12|
205e41f4b71Sopenharmony_ci|FUNC|napi_define_sendable_class|创建一个sendable类。|12|
206e41f4b71Sopenharmony_ci|FUNC|napi_create_sendable_object_with_properties | 使用给定的napi_property_descriptor创建一个sendable对象。|12|
207e41f4b71Sopenharmony_ci|FUNC|napi_create_sendable_array | 创建一个sendable数组。|12|
208e41f4b71Sopenharmony_ci|FUNC|napi_create_sendable_array_with_length | 创建一个指定长度的sendable数组。|12|
209e41f4b71Sopenharmony_ci|FUNC|napi_create_sendable_arraybuffer | 创建一个sendable ArrayBuffer。|12|
210e41f4b71Sopenharmony_ci|FUNC|napi_create_sendable_typedarray | 创建一个sendable TypedArray。|12|
211e41f4b71Sopenharmony_ci|FUNC|napi_wrap_sendable | 包裹一个native实例到ArkTS对象中。|12|
212e41f4b71Sopenharmony_ci|FUNC|napi_wrap_sendable_with_size | 包裹一个native实例到ArkTS对象中并指定大小。|12|
213e41f4b71Sopenharmony_ci|FUNC|napi_unwrap_sendable | 获取ArkTS对象包裹的native实例。|12|
214e41f4b71Sopenharmony_ci|FUNC|napi_remove_wrap_sendable | 移除并获取ArkTS对象包裹的native实例。|12|
215e41f4b71Sopenharmony_ci
216e41f4b71Sopenharmony_ci### napi_qos_t
217e41f4b71Sopenharmony_ci
218e41f4b71Sopenharmony_ci```cpp
219e41f4b71Sopenharmony_citypedef enum {
220e41f4b71Sopenharmony_ci    napi_qos_background = 0,      // 低等级,用户不可见任务,例如数据同步、备份。
221e41f4b71Sopenharmony_ci    napi_qos_utility = 1,         // 中低等级,不需要立即看到响应效果的任务,例如下载或导入数据。
222e41f4b71Sopenharmony_ci    napi_qos_default = 2,         // 默认
223e41f4b71Sopenharmony_ci    napi_qos_user_initiated = 3,  // 高等级,用户触发并且可见进展,例如打开文档。
224e41f4b71Sopenharmony_ci} napi_qos_t;
225e41f4b71Sopenharmony_ci```
226e41f4b71Sopenharmony_ci
227e41f4b71Sopenharmony_ci**描述:**
228e41f4b71Sopenharmony_ci表示QoS的枚举值,QoS决定了线程调度的优先级
229e41f4b71Sopenharmony_ci
230e41f4b71Sopenharmony_ci### napi_event_mode
231e41f4b71Sopenharmony_ci
232e41f4b71Sopenharmony_ci```cpp
233e41f4b71Sopenharmony_citypedef enum {
234e41f4b71Sopenharmony_ci    napi_event_mode_default = 0,  // 阻塞式的运行底层事件循环,直到循环中没有任何任务时退出事件循环。
235e41f4b71Sopenharmony_ci    napi_event_mode_nowait = 1,   // 非阻塞式的运行底层事件循环,尝试去处理一个任务,处理完之后退出事件循环;如果事件循环中没有任务,立刻退出事件循环。
236e41f4b71Sopenharmony_ci} napi_event_mode;
237e41f4b71Sopenharmony_ci```
238e41f4b71Sopenharmony_ci
239e41f4b71Sopenharmony_ci**描述:**
240e41f4b71Sopenharmony_ci用于运行事件循环的事件模式。
241e41f4b71Sopenharmony_ci
242e41f4b71Sopenharmony_ci### napi_queue_async_work_with_qos
243e41f4b71Sopenharmony_ci
244e41f4b71Sopenharmony_ci```cpp
245e41f4b71Sopenharmony_cinapi_status napi_queue_async_work_with_qos(napi_env env,
246e41f4b71Sopenharmony_ci                                           napi_async_work work,
247e41f4b71Sopenharmony_ci                                           napi_qos_t qos);
248e41f4b71Sopenharmony_ci```
249e41f4b71Sopenharmony_ci
250e41f4b71Sopenharmony_ci**描述:**
251e41f4b71Sopenharmony_ci
252e41f4b71Sopenharmony_ci将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。
253e41f4b71Sopenharmony_ci
254e41f4b71Sopenharmony_ci**参数:**
255e41f4b71Sopenharmony_ci
256e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
257e41f4b71Sopenharmony_ci
258e41f4b71Sopenharmony_ci- [in] work: 一个表示异步工作项的对象。这个对象通常是通过napi_create_async_work函数创建的。
259e41f4b71Sopenharmony_ci
260e41f4b71Sopenharmony_ci- [in] qos: 决定了线程调度的优先级。
261e41f4b71Sopenharmony_ci
262e41f4b71Sopenharmony_ci**返回:**
263e41f4b71Sopenharmony_ci
264e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
265e41f4b71Sopenharmony_ci
266e41f4b71Sopenharmony_ci### napi_run_script_path
267e41f4b71Sopenharmony_ci
268e41f4b71Sopenharmony_ci```cpp
269e41f4b71Sopenharmony_cinapi_status napi_run_script_path(napi_env env,
270e41f4b71Sopenharmony_ci                                 const char* abcPath,
271e41f4b71Sopenharmony_ci                                 napi_value* result);
272e41f4b71Sopenharmony_ci```
273e41f4b71Sopenharmony_ci
274e41f4b71Sopenharmony_ci**描述:**
275e41f4b71Sopenharmony_ci
276e41f4b71Sopenharmony_ci运行指定abc文件。
277e41f4b71Sopenharmony_ci
278e41f4b71Sopenharmony_ci**参数:**
279e41f4b71Sopenharmony_ci
280e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
281e41f4b71Sopenharmony_ci
282e41f4b71Sopenharmony_ci- [in] abcPath: 要运行的脚本的JavaScript路径。这是一个字符串,指定了要运行的脚本文件的位置。
283e41f4b71Sopenharmony_ci
284e41f4b71Sopenharmony_ci- [out] result: 一个指向napi_value类型的指针,用于存储运行脚本的结果。
285e41f4b71Sopenharmony_ci
286e41f4b71Sopenharmony_ci**返回:**
287e41f4b71Sopenharmony_ci
288e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
289e41f4b71Sopenharmony_ci
290e41f4b71Sopenharmony_ci### napi_load_module
291e41f4b71Sopenharmony_ci
292e41f4b71Sopenharmony_ci```cpp
293e41f4b71Sopenharmony_cinapi_status napi_load_module(napi_env env,
294e41f4b71Sopenharmony_ci                             const char* path,
295e41f4b71Sopenharmony_ci                             napi_value* result);
296e41f4b71Sopenharmony_ci```
297e41f4b71Sopenharmony_ci
298e41f4b71Sopenharmony_ci**描述:**
299e41f4b71Sopenharmony_ci
300e41f4b71Sopenharmony_ci加载系统模块或开发者自定义的模块,返回模块的命名空间。
301e41f4b71Sopenharmony_ci
302e41f4b71Sopenharmony_ci**参数:**
303e41f4b71Sopenharmony_ci
304e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
305e41f4b71Sopenharmony_ci
306e41f4b71Sopenharmony_ci- [in] path: 要加载的系统模块的名称或开发者自定义模块的路径。
307e41f4b71Sopenharmony_ci
308e41f4b71Sopenharmony_ci- [out] result: 一个指向napi_value类型的指针,用于存储加载模块的结果。
309e41f4b71Sopenharmony_ci
310e41f4b71Sopenharmony_ci**返回:**
311e41f4b71Sopenharmony_ci
312e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
313e41f4b71Sopenharmony_ci
314e41f4b71Sopenharmony_ci### napi_create_object_with_properties
315e41f4b71Sopenharmony_ci
316e41f4b71Sopenharmony_ci```cpp
317e41f4b71Sopenharmony_cinapi_status napi_create_object_with_properties(napi_env env,
318e41f4b71Sopenharmony_ci                                               napi_value* result,
319e41f4b71Sopenharmony_ci                                               size_t property_count,
320e41f4b71Sopenharmony_ci                                               const napi_property_descriptor* properties);
321e41f4b71Sopenharmony_ci```
322e41f4b71Sopenharmony_ci
323e41f4b71Sopenharmony_ci**描述:**
324e41f4b71Sopenharmony_ci
325e41f4b71Sopenharmony_ci属性描述符napi_property_descriptor用于描述一个属性,它包括属性的名称获取和设置方法、属性特性等信息。通过传入这些描述符,可以在创建对象时就定义属性。
326e41f4b71Sopenharmony_ci
327e41f4b71Sopenharmony_ci使用给定的napi_property_descriptor创建js Object。descriptor的键名必须为string,且不可转为number。
328e41f4b71Sopenharmony_ci
329e41f4b71Sopenharmony_ci**参数:**
330e41f4b71Sopenharmony_ci
331e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
332e41f4b71Sopenharmony_ci
333e41f4b71Sopenharmony_ci- [out] result: 一个指向napi_value类型的指针,用于存储创建的对象。
334e41f4b71Sopenharmony_ci
335e41f4b71Sopenharmony_ci- [in] property_count: 要添加到对象中的属性的数量。
336e41f4b71Sopenharmony_ci
337e41f4b71Sopenharmony_ci- [in] properties: 一个指向napi_property_descriptor数组的指针,描述了要添加到对象中的属性的信息。
338e41f4b71Sopenharmony_ci
339e41f4b71Sopenharmony_ci**返回:**
340e41f4b71Sopenharmony_ci
341e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
342e41f4b71Sopenharmony_ci
343e41f4b71Sopenharmony_ci### napi_create_object_with_named_properties
344e41f4b71Sopenharmony_ci
345e41f4b71Sopenharmony_ci```cpp
346e41f4b71Sopenharmony_cinapi_status napi_create_object_with_named_properties(napi_env env,
347e41f4b71Sopenharmony_ci                                                     napi_value* result,
348e41f4b71Sopenharmony_ci                                                     size_t property_count,
349e41f4b71Sopenharmony_ci                                                     const char** keys,
350e41f4b71Sopenharmony_ci                                                     const napi_value* values);
351e41f4b71Sopenharmony_ci```
352e41f4b71Sopenharmony_ci
353e41f4b71Sopenharmony_ci**描述:**
354e41f4b71Sopenharmony_ci
355e41f4b71Sopenharmony_ci使用给定的napi_value和键名创建js Object。键名必须为string,且不可转为number。
356e41f4b71Sopenharmony_ci
357e41f4b71Sopenharmony_ci**参数:**
358e41f4b71Sopenharmony_ci
359e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
360e41f4b71Sopenharmony_ci
361e41f4b71Sopenharmony_ci- [out] result: 一个指向napi_value类型的指针,用于存储创建的对象。
362e41f4b71Sopenharmony_ci
363e41f4b71Sopenharmony_ci- [in] property_count: 要添加到对象中的属性的数量。
364e41f4b71Sopenharmony_ci
365e41f4b71Sopenharmony_ci- [in] keys: 一个指向const char*数组的指针,表示属性的名称。
366e41f4b71Sopenharmony_ci
367e41f4b71Sopenharmony_ci- [in] values: 一个指向napi_value数组的指针,表示属性的值,与属性名称一一对应。
368e41f4b71Sopenharmony_ci
369e41f4b71Sopenharmony_ci**返回:**
370e41f4b71Sopenharmony_ci
371e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
372e41f4b71Sopenharmony_ci
373e41f4b71Sopenharmony_ci### napi_coerce_to_native_binding_object
374e41f4b71Sopenharmony_ci
375e41f4b71Sopenharmony_ci```cpp
376e41f4b71Sopenharmony_cinapi_status napi_coerce_to_native_binding_object(napi_env env,
377e41f4b71Sopenharmony_ci                                                 napi_value js_object,
378e41f4b71Sopenharmony_ci                                                 napi_native_binding_detach_callback detach_cb,
379e41f4b71Sopenharmony_ci                                                 napi_native_binding_attach_callback attach_cb,
380e41f4b71Sopenharmony_ci                                                 void* native_object,
381e41f4b71Sopenharmony_ci                                                 void* hint);
382e41f4b71Sopenharmony_ci```
383e41f4b71Sopenharmony_ci
384e41f4b71Sopenharmony_ci**描述:**
385e41f4b71Sopenharmony_ci
386e41f4b71Sopenharmony_ci用于给JS Object绑定回调和回调所需的参数,转成携带Native信息的JS Object。
387e41f4b71Sopenharmony_ci
388e41f4b71Sopenharmony_ci**参数:**
389e41f4b71Sopenharmony_ci
390e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
391e41f4b71Sopenharmony_ci
392e41f4b71Sopenharmony_ci- [in] js_object: 要转换的JavaScript对象。
393e41f4b71Sopenharmony_ci
394e41f4b71Sopenharmony_ci- [in] detach_cb: 解绑回调,一般在序列化时调用,可在对象解绑时执行一些清理操作。
395e41f4b71Sopenharmony_ci
396e41f4b71Sopenharmony_ci- [in] attach_cb: 绑定回调,一般在序列化时调用。
397e41f4b71Sopenharmony_ci
398e41f4b71Sopenharmony_ci- [in] native_object: 需要传递给回调的参数,不能为空。
399e41f4b71Sopenharmony_ci
400e41f4b71Sopenharmony_ci- [in] hint: 一个指针,可以用于传递附加的信息给回调函数。
401e41f4b71Sopenharmony_ci
402e41f4b71Sopenharmony_ci**返回:**
403e41f4b71Sopenharmony_ci
404e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
405e41f4b71Sopenharmony_ci
406e41f4b71Sopenharmony_ci### napi_create_ark_runtime
407e41f4b71Sopenharmony_ci
408e41f4b71Sopenharmony_ci```cpp
409e41f4b71Sopenharmony_cinapi_status napi_create_ark_runtime(napi_env *env)
410e41f4b71Sopenharmony_ci```
411e41f4b71Sopenharmony_ci
412e41f4b71Sopenharmony_ci**描述:**
413e41f4b71Sopenharmony_ci
414e41f4b71Sopenharmony_ci创建基础运行时环境。
415e41f4b71Sopenharmony_ci
416e41f4b71Sopenharmony_ci**参数:**
417e41f4b71Sopenharmony_ci
418e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
419e41f4b71Sopenharmony_ci
420e41f4b71Sopenharmony_ci**返回:**
421e41f4b71Sopenharmony_ci
422e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
423e41f4b71Sopenharmony_ci
424e41f4b71Sopenharmony_ci### napi_destroy_ark_runtime
425e41f4b71Sopenharmony_ci
426e41f4b71Sopenharmony_ci```cpp
427e41f4b71Sopenharmony_cinapi_status napi_destroy_ark_runtime(napi_env *env)
428e41f4b71Sopenharmony_ci```
429e41f4b71Sopenharmony_ci
430e41f4b71Sopenharmony_ci**描述:**
431e41f4b71Sopenharmony_ci
432e41f4b71Sopenharmony_ci销毁基础运行时环境。
433e41f4b71Sopenharmony_ci
434e41f4b71Sopenharmony_ci**参数:**
435e41f4b71Sopenharmony_ci
436e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
437e41f4b71Sopenharmony_ci
438e41f4b71Sopenharmony_ci**返回:**
439e41f4b71Sopenharmony_ci
440e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
441e41f4b71Sopenharmony_ci
442e41f4b71Sopenharmony_ci### napi_run_event_loop
443e41f4b71Sopenharmony_ci
444e41f4b71Sopenharmony_ci```cpp
445e41f4b71Sopenharmony_cinapi_status napi_run_event_loop(napi_env env, napi_event_mode mode)
446e41f4b71Sopenharmony_ci```
447e41f4b71Sopenharmony_ci
448e41f4b71Sopenharmony_ci**描述:**
449e41f4b71Sopenharmony_ci
450e41f4b71Sopenharmony_ci触发底层的事件循环。
451e41f4b71Sopenharmony_ci
452e41f4b71Sopenharmony_ci**参数:**
453e41f4b71Sopenharmony_ci
454e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
455e41f4b71Sopenharmony_ci- [in] mode: 用于运行事件循环的事件模式。
456e41f4b71Sopenharmony_ci
457e41f4b71Sopenharmony_ci**返回:**
458e41f4b71Sopenharmony_ci
459e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
460e41f4b71Sopenharmony_ci
461e41f4b71Sopenharmony_ci### napi_stop_event_loop
462e41f4b71Sopenharmony_ci
463e41f4b71Sopenharmony_ci```cpp
464e41f4b71Sopenharmony_cinapi_status napi_stop_event_loop(napi_env env)
465e41f4b71Sopenharmony_ci```
466e41f4b71Sopenharmony_ci
467e41f4b71Sopenharmony_ci**描述:**
468e41f4b71Sopenharmony_ci
469e41f4b71Sopenharmony_ci停止底层的事件循环。
470e41f4b71Sopenharmony_ci
471e41f4b71Sopenharmony_ci**参数:**
472e41f4b71Sopenharmony_ci
473e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
474e41f4b71Sopenharmony_ci
475e41f4b71Sopenharmony_ci**返回:**
476e41f4b71Sopenharmony_ci
477e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
478e41f4b71Sopenharmony_ci
479e41f4b71Sopenharmony_ci### napi_load_module_with_info
480e41f4b71Sopenharmony_ci
481e41f4b71Sopenharmony_ci```cpp
482e41f4b71Sopenharmony_cinapi_status napi_load_module_with_info(napi_env env,
483e41f4b71Sopenharmony_ci                                       const char* path,
484e41f4b71Sopenharmony_ci                                       const char* module_info,
485e41f4b71Sopenharmony_ci                                       napi_value* result)
486e41f4b71Sopenharmony_ci```
487e41f4b71Sopenharmony_ci
488e41f4b71Sopenharmony_ci**描述:**
489e41f4b71Sopenharmony_ci
490e41f4b71Sopenharmony_ci将abc文件作为模块加载,返回模块的命名空间。可在新创建的ArkTS基础运行时环境中使用。
491e41f4b71Sopenharmony_ci
492e41f4b71Sopenharmony_ci**参数:**
493e41f4b71Sopenharmony_ci
494e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
495e41f4b71Sopenharmony_ci
496e41f4b71Sopenharmony_ci- [in] path: 要加载的模块的路径。
497e41f4b71Sopenharmony_ci
498e41f4b71Sopenharmony_ci- [in] module_info: 模块信息。这是一个包含模块信息字符串。模块信息可以用于指定模块的版本、作者、描述等详细信息。
499e41f4b71Sopenharmony_ci
500e41f4b71Sopenharmony_ci- [out] result: 指向napi_value的指针,用于接收模块的结果。
501e41f4b71Sopenharmony_ci
502e41f4b71Sopenharmony_ci**返回:**
503e41f4b71Sopenharmony_ci
504e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
505e41f4b71Sopenharmony_ci
506e41f4b71Sopenharmony_ci### napi_serialize
507e41f4b71Sopenharmony_ci
508e41f4b71Sopenharmony_ci```cpp
509e41f4b71Sopenharmony_cinapi_status napi_serialize(napi_env env,
510e41f4b71Sopenharmony_ci                           napi_value object,
511e41f4b71Sopenharmony_ci                           napi_value transfer_list,
512e41f4b71Sopenharmony_ci                           napi_value clone_list,
513e41f4b71Sopenharmony_ci                           void** result)
514e41f4b71Sopenharmony_ci```
515e41f4b71Sopenharmony_ci
516e41f4b71Sopenharmony_ci**描述:**
517e41f4b71Sopenharmony_ci
518e41f4b71Sopenharmony_ci将ArkTS对象转换为native数据。
519e41f4b71Sopenharmony_ci
520e41f4b71Sopenharmony_ci**参数:**
521e41f4b71Sopenharmony_ci
522e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
523e41f4b71Sopenharmony_ci
524e41f4b71Sopenharmony_ci- [in] object: 要序列化的JavaScript对象。
525e41f4b71Sopenharmony_ci
526e41f4b71Sopenharmony_ci- [in] transfer_list: 传输列表,包含需要在序列化过程中转移的JavaScript对象。
527e41f4b71Sopenharmony_ci
528e41f4b71Sopenharmony_ci- [in] clone_list: 克隆列表,包含需要在序列化过程中克隆的JavaScript对象。
529e41f4b71Sopenharmony_ci
530e41f4b71Sopenharmony_ci- [out] result: 用于接收序列化结果的指针。在调用完成后,指向实际结果的指针会存储在此位置。
531e41f4b71Sopenharmony_ci
532e41f4b71Sopenharmony_ci**返回:**
533e41f4b71Sopenharmony_ci
534e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
535e41f4b71Sopenharmony_ci
536e41f4b71Sopenharmony_ci### napi_deserialize
537e41f4b71Sopenharmony_ci
538e41f4b71Sopenharmony_ci```cpp
539e41f4b71Sopenharmony_cinapi_status napi_deserialize(napi_env env, void* buffer, napi_value* object)
540e41f4b71Sopenharmony_ci```
541e41f4b71Sopenharmony_ci
542e41f4b71Sopenharmony_ci**描述:**
543e41f4b71Sopenharmony_ci
544e41f4b71Sopenharmony_ci将native数据转为ArkTS对象。
545e41f4b71Sopenharmony_ci
546e41f4b71Sopenharmony_ci**参数:**
547e41f4b71Sopenharmony_ci
548e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
549e41f4b71Sopenharmony_ci
550e41f4b71Sopenharmony_ci- [in] buffer: 指向包含二进制数据的指针。这些二进制数据需要被反序列化为JavaScript对象。
551e41f4b71Sopenharmony_ci
552e41f4b71Sopenharmony_ci- [out] object: 用于接收反序列化后的JavaScript对象。
553e41f4b71Sopenharmony_ci
554e41f4b71Sopenharmony_ci**返回:**
555e41f4b71Sopenharmony_ci
556e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
557e41f4b71Sopenharmony_ci
558e41f4b71Sopenharmony_ci### napi_delete_serialization_data
559e41f4b71Sopenharmony_ci
560e41f4b71Sopenharmony_ci```cpp
561e41f4b71Sopenharmony_cinapi_status napi_delete_serialization_data(napi_env env, void* buffer)
562e41f4b71Sopenharmony_ci```
563e41f4b71Sopenharmony_ci
564e41f4b71Sopenharmony_ci**描述:**
565e41f4b71Sopenharmony_ci
566e41f4b71Sopenharmony_ci删除序列化数据。
567e41f4b71Sopenharmony_ci
568e41f4b71Sopenharmony_ci**参数:**
569e41f4b71Sopenharmony_ci
570e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
571e41f4b71Sopenharmony_ci
572e41f4b71Sopenharmony_ci- [in] buffer: 指向包含序列化数据的内存缓冲区的指针。这些数据在序列化完成后不再需要,并且可以通过调用此函数来释放相应的内存。
573e41f4b71Sopenharmony_ci
574e41f4b71Sopenharmony_ci**返回:**
575e41f4b71Sopenharmony_ci
576e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
577e41f4b71Sopenharmony_ci
578e41f4b71Sopenharmony_ci### napi_call_threadsafe_function_with_priority
579e41f4b71Sopenharmony_ci
580e41f4b71Sopenharmony_ci```cpp
581e41f4b71Sopenharmony_cinapi_status napi_call_threadsafe_function_with_priority(napi_threadsafe_function func,
582e41f4b71Sopenharmony_ci                                                        void *data,
583e41f4b71Sopenharmony_ci                                                        napi_task_priority priority,
584e41f4b71Sopenharmony_ci                                                        bool isTail)
585e41f4b71Sopenharmony_ci```
586e41f4b71Sopenharmony_ci
587e41f4b71Sopenharmony_ci**描述:**
588e41f4b71Sopenharmony_ci
589e41f4b71Sopenharmony_ci将指定优先级和入队方式的任务投递到ArkTS主线程。
590e41f4b71Sopenharmony_ci
591e41f4b71Sopenharmony_ci**参数:**
592e41f4b71Sopenharmony_ci
593e41f4b71Sopenharmony_ci- [in] func: 线程安全函数对象,在创建线程安全函数时返回。
594e41f4b71Sopenharmony_ci
595e41f4b71Sopenharmony_ci- [in] data: 传递给 JavaScript 回调函数的参数数据。
596e41f4b71Sopenharmony_ci
597e41f4b71Sopenharmony_ci- [in] priority: 指定调用 JavaScript 回调函数的任务优先级。
598e41f4b71Sopenharmony_ci
599e41f4b71Sopenharmony_ci- [in] isTail: 一个布尔值,指示调用是否应该排队等待在事件循环的尾部执行。如果为 true,则调用将在事件循环的尾部执行;如果为 false,则调用将立即执行,不会排队等待。
600e41f4b71Sopenharmony_ci
601e41f4b71Sopenharmony_ci**返回:**
602e41f4b71Sopenharmony_ci
603e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
604e41f4b71Sopenharmony_ci
605e41f4b71Sopenharmony_ci### napi_is_sendable
606e41f4b71Sopenharmony_ci
607e41f4b71Sopenharmony_ci```cpp
608e41f4b71Sopenharmony_cinapi_status napi_is_sendable(napi_env env, napi_value value, bool* result)
609e41f4b71Sopenharmony_ci```
610e41f4b71Sopenharmony_ci
611e41f4b71Sopenharmony_ci**描述:**
612e41f4b71Sopenharmony_ci
613e41f4b71Sopenharmony_ci判断给定JS value是否是Sendable的。
614e41f4b71Sopenharmony_ci
615e41f4b71Sopenharmony_ci**参数:**
616e41f4b71Sopenharmony_ci
617e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
618e41f4b71Sopenharmony_ci
619e41f4b71Sopenharmony_ci- [in] value: 一个napi_value类型的参数,是需要判断的值。
620e41f4b71Sopenharmony_ci
621e41f4b71Sopenharmony_ci- [out] result: 一个bool类型的指针,用于存储判断结果。
622e41f4b71Sopenharmony_ci
623e41f4b71Sopenharmony_ci**返回:**
624e41f4b71Sopenharmony_ci
625e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
626e41f4b71Sopenharmony_ci
627e41f4b71Sopenharmony_ci
628e41f4b71Sopenharmony_ci### napi_define_sendable_class
629e41f4b71Sopenharmony_ci
630e41f4b71Sopenharmony_ci```cpp
631e41f4b71Sopenharmony_cinapi_status napi_define_sendable_class(napi_env env,
632e41f4b71Sopenharmony_ci                                       const char* utf8name,
633e41f4b71Sopenharmony_ci                                       size_t length,
634e41f4b71Sopenharmony_ci                                       napi_callback constructor,
635e41f4b71Sopenharmony_ci                                       void* data,
636e41f4b71Sopenharmony_ci                                       size_t property_count,
637e41f4b71Sopenharmony_ci                                       const napi_property_descriptor* properties,
638e41f4b71Sopenharmony_ci                                       napi_value parent,
639e41f4b71Sopenharmony_ci                                       napi_value* result)
640e41f4b71Sopenharmony_ci
641e41f4b71Sopenharmony_ci
642e41f4b71Sopenharmony_ci```
643e41f4b71Sopenharmony_ci
644e41f4b71Sopenharmony_ci**描述:**
645e41f4b71Sopenharmony_ci
646e41f4b71Sopenharmony_ci创建一个sendable类。
647e41f4b71Sopenharmony_ci
648e41f4b71Sopenharmony_ci**参数:**
649e41f4b71Sopenharmony_ci
650e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
651e41f4b71Sopenharmony_ci
652e41f4b71Sopenharmony_ci- [in] utf8name:一个const char*类型的参数,表示类的名称。
653e41f4b71Sopenharmony_ci
654e41f4b71Sopenharmony_ci- [in] length:一个size_t类型的参数,表示类名称的字节数。
655e41f4b71Sopenharmony_ci
656e41f4b71Sopenharmony_ci- [in] constructor:一个napi_callback类型的参数,表示类的构造函数。
657e41f4b71Sopenharmony_ci
658e41f4b71Sopenharmony_ci- [in] data:[可选]一个void*类型的参数,表示构造函数的附加数据。
659e41f4b71Sopenharmony_ci
660e41f4b71Sopenharmony_ci- [in] property_count:一个size_t类型的参数,表示类的属性数量。
661e41f4b71Sopenharmony_ci
662e41f4b71Sopenharmony_ci- [in] properties:[可选]一个const napi_property_descriptor*类型的参数,表示类的属性描述符数组。
663e41f4b71Sopenharmony_ci
664e41f4b71Sopenharmony_ci- [in] parent:[可选]一个napi_value类型的参数,表示父类。
665e41f4b71Sopenharmony_ci
666e41f4b71Sopenharmony_ci- [out] result:一个napi_value类型的指针,用于存储创建的对象。
667e41f4b71Sopenharmony_ci
668e41f4b71Sopenharmony_ci**返回:**
669e41f4b71Sopenharmony_ci
670e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
671e41f4b71Sopenharmony_ci
672e41f4b71Sopenharmony_ci### napi_create_sendable_object_with_properties
673e41f4b71Sopenharmony_ci
674e41f4b71Sopenharmony_ci```cpp
675e41f4b71Sopenharmony_cinapi_status napi_create_sendable_object_with_properties(napi_env env,
676e41f4b71Sopenharmony_ci                                                        size_t property_count,
677e41f4b71Sopenharmony_ci                                                        const napi_property_descriptor* properties,
678e41f4b71Sopenharmony_ci                                                        napi_value* result)
679e41f4b71Sopenharmony_ci```
680e41f4b71Sopenharmony_ci
681e41f4b71Sopenharmony_ci**描述:**
682e41f4b71Sopenharmony_ci
683e41f4b71Sopenharmony_ci使用给定的napi_property_descriptor创建一个sendable对象。
684e41f4b71Sopenharmony_ci
685e41f4b71Sopenharmony_ci**参数:**
686e41f4b71Sopenharmony_ci
687e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
688e41f4b71Sopenharmony_ci
689e41f4b71Sopenharmony_ci- [in] property_count:一个size_t类型的参数,表示属性数量。
690e41f4b71Sopenharmony_ci
691e41f4b71Sopenharmony_ci- [in] properties:一个const napi_property_descriptor*类型的参数,表示属性描述符数组。
692e41f4b71Sopenharmony_ci
693e41f4b71Sopenharmony_ci- [out] result:一个napi_value类型的指针,用于存储创建的对象。
694e41f4b71Sopenharmony_ci
695e41f4b71Sopenharmony_ci**返回:**
696e41f4b71Sopenharmony_ci
697e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
698e41f4b71Sopenharmony_ci
699e41f4b71Sopenharmony_ci### napi_create_sendable_array
700e41f4b71Sopenharmony_ci
701e41f4b71Sopenharmony_ci```cpp
702e41f4b71Sopenharmony_cinapi_status napi_create_sendable_array(napi_env env, napi_value* result)
703e41f4b71Sopenharmony_ci```
704e41f4b71Sopenharmony_ci
705e41f4b71Sopenharmony_ci**描述:**
706e41f4b71Sopenharmony_ci
707e41f4b71Sopenharmony_ci创建一个sendable数组。
708e41f4b71Sopenharmony_ci
709e41f4b71Sopenharmony_ci**参数:**
710e41f4b71Sopenharmony_ci
711e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
712e41f4b71Sopenharmony_ci
713e41f4b71Sopenharmony_ci- [out] result:一个napi_value类型的指针,用于存储创建的数组。
714e41f4b71Sopenharmony_ci
715e41f4b71Sopenharmony_ci**返回:**
716e41f4b71Sopenharmony_ci
717e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
718e41f4b71Sopenharmony_ci
719e41f4b71Sopenharmony_ci### napi_create_sendable_array_with_length
720e41f4b71Sopenharmony_ci
721e41f4b71Sopenharmony_ci```cpp
722e41f4b71Sopenharmony_cinapi_status napi_create_sendable_array_with_length(napi_env env, size_t length, napi_value* result)
723e41f4b71Sopenharmony_ci```
724e41f4b71Sopenharmony_ci
725e41f4b71Sopenharmony_ci**描述:**
726e41f4b71Sopenharmony_ci
727e41f4b71Sopenharmony_ci创建一个指定长度的sendable数组。
728e41f4b71Sopenharmony_ci
729e41f4b71Sopenharmony_ci**参数:**
730e41f4b71Sopenharmony_ci
731e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
732e41f4b71Sopenharmony_ci
733e41f4b71Sopenharmony_ci- [in] length:一个size_t类型的参数,表示数组的长度。
734e41f4b71Sopenharmony_ci
735e41f4b71Sopenharmony_ci- [out] result:一个napi_value类型的指针,用于存储创建的数组。
736e41f4b71Sopenharmony_ci
737e41f4b71Sopenharmony_ci**返回:**
738e41f4b71Sopenharmony_ci
739e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
740e41f4b71Sopenharmony_ci
741e41f4b71Sopenharmony_ci### napi_create_sendable_arraybuffer
742e41f4b71Sopenharmony_ci
743e41f4b71Sopenharmony_ci```cpp
744e41f4b71Sopenharmony_cinapi_status napi_create_sendable_arraybuffer(napi_env env, size_t byte_length, void** data, napi_value* result)
745e41f4b71Sopenharmony_ci```
746e41f4b71Sopenharmony_ci
747e41f4b71Sopenharmony_ci**描述:**
748e41f4b71Sopenharmony_ci
749e41f4b71Sopenharmony_ci创建一个sendable ArrayBuffer。
750e41f4b71Sopenharmony_ci
751e41f4b71Sopenharmony_ci**参数:**
752e41f4b71Sopenharmony_ci
753e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
754e41f4b71Sopenharmony_ci
755e41f4b71Sopenharmony_ci- [in] byte_length:要创建的ArrayBuffer的大小。
756e41f4b71Sopenharmony_ci
757e41f4b71Sopenharmony_ci- [in] data:指向底层字节缓冲区的指针。
758e41f4b71Sopenharmony_ci
759e41f4b71Sopenharmony_ci- [out] result:一个napi_value类型的指针,用于存储创建的ArrayBuffer。
760e41f4b71Sopenharmony_ci
761e41f4b71Sopenharmony_ci**返回:**
762e41f4b71Sopenharmony_ci
763e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
764e41f4b71Sopenharmony_ci
765e41f4b71Sopenharmony_ci### napi_create_sendable_typedarray
766e41f4b71Sopenharmony_ci
767e41f4b71Sopenharmony_ci```cpp
768e41f4b71Sopenharmony_cinapi_status napi_create_sendable_typedarray(napi_env env,
769e41f4b71Sopenharmony_ci                                            napi_typedarray_type type,
770e41f4b71Sopenharmony_ci                                            size_t length,
771e41f4b71Sopenharmony_ci                                            napi_value arraybuffer,
772e41f4b71Sopenharmony_ci                                            size_t byte_offset,
773e41f4b71Sopenharmony_ci                                            napi_value* result);
774e41f4b71Sopenharmony_ci```
775e41f4b71Sopenharmony_ci
776e41f4b71Sopenharmony_ci**描述:**
777e41f4b71Sopenharmony_ci
778e41f4b71Sopenharmony_ci创建一个sendable TypedArray。
779e41f4b71Sopenharmony_ci
780e41f4b71Sopenharmony_ci**参数:**
781e41f4b71Sopenharmony_ci
782e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
783e41f4b71Sopenharmony_ci
784e41f4b71Sopenharmony_ci- [in] type:TypedArray 的类型。
785e41f4b71Sopenharmony_ci
786e41f4b71Sopenharmony_ci- [in] length:TypedArray 的长度。
787e41f4b71Sopenharmony_ci
788e41f4b71Sopenharmony_ci- [in] arraybuffer:一个 ArrayBuffer 实例。
789e41f4b71Sopenharmony_ci
790e41f4b71Sopenharmony_ci- [in] byte_offset:ArrayBuffer 的偏移量。
791e41f4b71Sopenharmony_ci
792e41f4b71Sopenharmony_ci- [out] result:一个napi_value类型的指针,用于存储创建的TypedArray。
793e41f4b71Sopenharmony_ci
794e41f4b71Sopenharmony_ci**返回:**
795e41f4b71Sopenharmony_ci
796e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
797e41f4b71Sopenharmony_ci
798e41f4b71Sopenharmony_ci### napi_wrap_sendable
799e41f4b71Sopenharmony_ci
800e41f4b71Sopenharmony_ci```cpp
801e41f4b71Sopenharmony_cinapi_status napi_wrap_sendable(napi_env env,
802e41f4b71Sopenharmony_ci                               napi_value js_object,
803e41f4b71Sopenharmony_ci                               void* native_object,
804e41f4b71Sopenharmony_ci                               napi_finalize finalize_cb,
805e41f4b71Sopenharmony_ci                               void* finalize_hint);
806e41f4b71Sopenharmony_ci```
807e41f4b71Sopenharmony_ci
808e41f4b71Sopenharmony_ci**描述:**
809e41f4b71Sopenharmony_ci
810e41f4b71Sopenharmony_ci包裹一个native实例到ArkTS对象中。
811e41f4b71Sopenharmony_ci
812e41f4b71Sopenharmony_ci**参数:**
813e41f4b71Sopenharmony_ci
814e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
815e41f4b71Sopenharmony_ci
816e41f4b71Sopenharmony_ci- [in] js_object:ArkTS对象。
817e41f4b71Sopenharmony_ci
818e41f4b71Sopenharmony_ci- [in] native_object:将被包裹在ArkTS对象中的native实例。
819e41f4b71Sopenharmony_ci
820e41f4b71Sopenharmony_ci- [in] napi_finalize:[可选]ArkTS对象被销毁时调用的回调函数。
821e41f4b71Sopenharmony_ci
822e41f4b71Sopenharmony_ci- [in] finalize_hint:[可选]上下文提示,会传递给回调函数。
823e41f4b71Sopenharmony_ci
824e41f4b71Sopenharmony_ci**返回:**
825e41f4b71Sopenharmony_ci
826e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
827e41f4b71Sopenharmony_ci
828e41f4b71Sopenharmony_ci### napi_wrap_sendable_with_size
829e41f4b71Sopenharmony_ci
830e41f4b71Sopenharmony_ci```cpp
831e41f4b71Sopenharmony_cinapi_status napi_wrap_sendable_with_size(napi_env env,
832e41f4b71Sopenharmony_ci                                         napi_value js_object,
833e41f4b71Sopenharmony_ci                                         void* native_object,
834e41f4b71Sopenharmony_ci                                         napi_finalize finalize_cb,
835e41f4b71Sopenharmony_ci                                         void* finalize_hint,
836e41f4b71Sopenharmony_ci                                         size_t native_binding_size);
837e41f4b71Sopenharmony_ci```
838e41f4b71Sopenharmony_ci
839e41f4b71Sopenharmony_ci**描述:**
840e41f4b71Sopenharmony_ci
841e41f4b71Sopenharmony_ci包装一个native实例到ArkTS对象中并指定大小。
842e41f4b71Sopenharmony_ci
843e41f4b71Sopenharmony_ci**参数:**
844e41f4b71Sopenharmony_ci
845e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
846e41f4b71Sopenharmony_ci
847e41f4b71Sopenharmony_ci- [in] js_object:ArkTS对象。
848e41f4b71Sopenharmony_ci
849e41f4b71Sopenharmony_ci- [in] native_object:将被包裹在ArkTS对象中的native实例。
850e41f4b71Sopenharmony_ci
851e41f4b71Sopenharmony_ci- [in] napi_finalize:[可选]ArkTS对象被销毁时调用的回调函数。
852e41f4b71Sopenharmony_ci
853e41f4b71Sopenharmony_ci- [in] finalize_hint:[可选]上下文提示,会传递给回调函数。
854e41f4b71Sopenharmony_ci
855e41f4b71Sopenharmony_ci- [in] native_binding_size:[可选]绑定的native实例的大小。
856e41f4b71Sopenharmony_ci
857e41f4b71Sopenharmony_ci**返回:**
858e41f4b71Sopenharmony_ci
859e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
860e41f4b71Sopenharmony_ci
861e41f4b71Sopenharmony_ci### napi_unwrap_sendable
862e41f4b71Sopenharmony_ci
863e41f4b71Sopenharmony_ci```cpp
864e41f4b71Sopenharmony_cinapi_status napi_unwrap_sendable(napi_env env, napi_value js_object, void** result)
865e41f4b71Sopenharmony_ci```
866e41f4b71Sopenharmony_ci
867e41f4b71Sopenharmony_ci**描述:**
868e41f4b71Sopenharmony_ci
869e41f4b71Sopenharmony_ci获取ArkTS对象包装的native实例。
870e41f4b71Sopenharmony_ci
871e41f4b71Sopenharmony_ci**参数:**
872e41f4b71Sopenharmony_ci
873e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
874e41f4b71Sopenharmony_ci
875e41f4b71Sopenharmony_ci- [in] js_object:ArkTS对象。
876e41f4b71Sopenharmony_ci
877e41f4b71Sopenharmony_ci- [out] result:包裹在ArkTS对象中的native实例。
878e41f4b71Sopenharmony_ci
879e41f4b71Sopenharmony_ci**返回:**
880e41f4b71Sopenharmony_ci
881e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
882e41f4b71Sopenharmony_ci
883e41f4b71Sopenharmony_ci### napi_remove_wrap_sendable
884e41f4b71Sopenharmony_ci
885e41f4b71Sopenharmony_ci```cpp
886e41f4b71Sopenharmony_cinapi_status napi_remove_wrap_sendable(napi_env env, napi_value js_object, void** result)
887e41f4b71Sopenharmony_ci```
888e41f4b71Sopenharmony_ci
889e41f4b71Sopenharmony_ci**描述:**
890e41f4b71Sopenharmony_ci
891e41f4b71Sopenharmony_ci移除并获取ArkTS对象包装的native实例。
892e41f4b71Sopenharmony_ci
893e41f4b71Sopenharmony_ci**参数:**
894e41f4b71Sopenharmony_ci
895e41f4b71Sopenharmony_ci- [in] env: Node-API的环境对象,表示当前的执行环境。
896e41f4b71Sopenharmony_ci
897e41f4b71Sopenharmony_ci- [in] js_object:ArkTS对象。
898e41f4b71Sopenharmony_ci
899e41f4b71Sopenharmony_ci- [out] result:包裹在ArkTS对象中的native实例。
900e41f4b71Sopenharmony_ci
901e41f4b71Sopenharmony_ci**返回:**
902e41f4b71Sopenharmony_ci
903e41f4b71Sopenharmony_ci如果API成功,则返回napi_ok。
904e41f4b71Sopenharmony_ci
905e41f4b71Sopenharmony_ci<!--no_check-->