往期鸿蒙5.0全套实战文章必看:(文中附带全栈鸿蒙5.0学习资料)
使用JSVM-API接口进行array相关开发
简介
使用 JSVM-API 接口进行数组(array)相关开发时,调用相关接口可以在 JSVM 模块中直接操作和处理 JavaScript 中的数组。
基本概念
使用 JSVM-API 接口进行数组(array)相关开发时,涉及的基本概念主要包括数组的创建、访问、修改、遍历以及与数组相关的操作。这些概念对于理解在 JSVM 模块中如何与 JavaScript 数组交互非常重要。以下是一些关键概念:
- 数组的创建:若在 JSVM 模块中需要创建一个新的 JavaScript 数组,可以使用提供的 OH_JSVM_CreateArray 接口创建数组,将数组传递给 JavaScript 层。
- 数组相关操作:在 JSVM 模块中通过对应的接口获取 JavaScript 数组的长度、检索指定索引处的元素以及设置指定索引处的元素值,从而实现 JSVM 模块与 JavaScript 数组的交互。
- TypedArray:JavaScript 中的 TypedArray 是一种用来描述二进制数据的类数组数据视图,可以简单理解为一种指定元素类型的数组,TypedArray 没有直接构造器,但是可以用它的子类构造器构造 TypedArray 类型的数据。TypedArray 的子类有:Int8Array、Uint8Array、Uint8ClampedArray、Int16Array、Int32Array 等。
- ArrayBuffer:ArrayBuffer 是固定长度的二进制数据缓冲区。
- DataView:DataView 是 JavaScript 中的一种视图,是可以从 ArrayBuffer 对象中读写多种数值类型的底层接口。
接口说明
接口 | 功能说明 |
---|---|
OH_JSVM_CreateArray | 创建一个新的 JavaScript 数组对象 |
OH_JSVM_CreateArrayWithLength | 创建一个指定长度的 JavaScript 数组对象 |
OH_JSVM_CreateTypedarray | 在现有的 ArrayBuffer 上创建一个 JavaScript TypedArray 对象,TypedArray 对象在底层数据缓冲区上提供类似数组的视图,其中每个元素都具有相同的底层二进制标量数据类型。需要注意,对于入参有以下要求:(length * size_of_element) + byte_offset 要不大于传入数组的大小(以字节为单位),size_of_element 指数组中元素的数据类型的大小,否则会引发 RangeError 异常。 |
OH_JSVM_CreateDataview | 在现有的 ArrayBuffer 上创建一个 JavaScript DataView 对象,DataView 对象在底层数据缓冲区上提供类似数组的视图,该 ArrayBuffer 允许有不同大小和类型的元素。要求 byte_length + byte_offset 小于或等于传入数组的字节大小,否则会引发 RangeError 异常。 |
OH_JSVM_GetArrayLength | 返回 Array 对象的长度 |
OH_JSVM_GetTypedarrayInfo | 获取 TypedArray(类型化数组)对象的信息 |
OH_JSVM_GetDataviewInfo | 获取 Dataview 对象的信息 |
OH_JSVM_IsArray | 判断一个 JavaScript 对象是否为 Array 类型对象 |
OH_JSVM_SetElement | 在给定对象的指定索引处设置元素 |
OH_JSVM_GetElement | 获取给定对象指定索引处的元素 |
OH_JSVM_HasElement | 若给定对象的指定索引处拥有属性,获取该元素 |
OH_JSVM_DeleteElement | 尝试删除给定对象的指定索引处的元素 |
OH_JSVM_IsDataview | 判断一个 JavaScript 对象是否为 Dataview 类型对象 |
OH_JSVM_IsTypedarray | 判断一个 JavaScript 对象是否为 Typedarray 类型对象 |
使用示例
JSVM-API 接口开发流程参考使用 JSVM-API 实现 JS 与 C/C++ 语言交互开发流程,本文仅对接口对应 C++ 相关代码进行展示。
OH_JSVM_CreateArray
创建一个新的 JavaScript 数组对象。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// CreateArray注册回调
static int DIFF_VALUE_FIVE = 5;
// OH_JSVM_CreateArray的样例方法
static JSVM_Value CreateArray(JSVM_Env env, JSVM_CallbackInfo info)
{
// 创建一个空数组
JSVM_Value array = nullptr;
JSVM_Status status = OH_JSVM_CreateArray(env, &array);
// 对创建的数组进行赋值
for (int i = 0; i < DIFF_VALUE_FIVE; i++) {
JSVM_Value element;
OH_JSVM_CreateInt32(env, i, &element);
OH_JSVM_SetElement(env, array, i, element);
}
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM CreateArray fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM CreateArray success");
}
return array;
}
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = CreateArray},
};
static JSVM_CallbackStruct *method = param;
// CreateArray方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"createArray", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
function testCreateArray() {
return createArray();
}
testCreateArray();
)JS";
OH_JSVM_CreateArrayWithLength
创建一个指定长度的 JavaScript 数组对象。
cpp 部分代码:
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_CreateArrayWithLength的样例方法
static JSVM_Value CreateArrayWithLength(JSVM_Env env, JSVM_CallbackInfo info)
{
size_t argc = 1;
JSVM_Value argv[1] = {nullptr};
JSVM_Value result = nullptr;
// 解析传递的参数OH_JSVM_GetCbInfo
OH_JSVM_GetCbInfo(env, info, &argc, argv, nullptr, nullptr);
// 获取传递的数组长度
int32_t length;
OH_JSVM_GetValueInt32(env, argv[0], &length);
// 使用OH_JSVM_CreateArrayWithLength创建传递固定长度的数组
JSVM_Status status = OH_JSVM_CreateArrayWithLength(env, length, &result);
if (status == JSVM_OK) {
// 给创建的数组设置值
for (int32_t i = 0; i < length; i++) {
JSVM_Value value;
OH_JSVM_CreateInt32(env, i, &value);
OH_JSVM_SetElement(env, result, i, value);
}
OH_LOG_INFO(LOG_APP, "JSVM CreateArrayWithLength success");
} else {
OH_LOG_ERROR(LOG_APP, "JSVM CreateArrayWithLength fail");
}
return result;
}
// CreateArrayWithLength注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = CreateArrayWithLength},
};
static JSVM_CallbackStruct *method = param;
// CreateArrayWithLength方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"createArrayWithLength", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
let num = 7;
function testCreateArrayWithLength(num){
return createArrayWithLength(num);
}
testCreateArrayWithLength(num);
)JS";
OH_JSVM_CreateTypedarray
在现有的 ArrayBuffer上 创建一个 JavaScript TypedArray 对象,TypedArray 对象在底层数据缓冲区上提供类似数组的视图,其中每个元素都具有相同的底层二进制标量数据类型。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_CreateTypedarray的样例方法
static int DIFF_VALUE_THREE = 3;
static JSVM_Value CreateTypedArray(JSVM_Env env, JSVM_CallbackInfo info)
{
size_t argc = 1;
JSVM_Value args[1] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
int32_t typeNum;
OH_JSVM_GetValueInt32(env, args[0], &typeNum);
JSVM_TypedarrayType arrayType;
// 用于存储每个元素的大小
size_t elementSize = 0;
// 转换为JSVM_TypedarrayType类型
arrayType = static_cast<JSVM_TypedarrayType>(typeNum);
switch (typeNum) {
case JSVM_INT8_ARRAY:
case JSVM_UINT8_ARRAY:
case JSVM_UINT8_CLAMPED_ARRAY:
elementSize = sizeof(int8_t);
break;
case JSVM_INT16_ARRAY:
case JSVM_UINT16_ARRAY:
elementSize = sizeof(int16_t);
break;
case JSVM_INT32_ARRAY:
case JSVM_UINT32_ARRAY:
elementSize = sizeof(int32_t);
break;
case JSVM_FLOAT32_ARRAY:
elementSize = sizeof(float);
break;
case JSVM_FLOAT64_ARRAY:
elementSize = sizeof(double);
break;
case JSVM_BIGINT64_ARRAY:
case JSVM_BIGUINT64_ARRAY:
elementSize = sizeof(int64_t);
break;
default:
// 默认创建JSVM_INT8_ARRAY类型
arrayType = JSVM_INT8_ARRAY;
elementSize = sizeof(int8_t);
break;
}
size_t length = DIFF_VALUE_THREE;
JSVM_Value arrayBuffer = nullptr;
JSVM_Value typedArray = nullptr;
void *data;
// 创建一个ArrayBuffer
OH_JSVM_CreateArraybuffer(env, length * elementSize, (void **)&data, &arrayBuffer);
// 根据给定类型创建TypedArray
JSVM_Status status = OH_JSVM_CreateTypedarray(env, arrayType, length, arrayBuffer, 0, &typedArray);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM CreateTypedArray fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM CreateTypedArray success");
}
return typedArray;
}
// CreateTypedArray注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = CreateTypedArray},
};
static JSVM_CallbackStruct *method = param;
// CreateTypedArray方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"createTypedArray", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
const type = {
INT8_ARRAY: 0,
UINT8_ARRAY: 1,
UINT8_CLAMPED_ARRAY: 2,
INT16_ARRAY: 3,
UINT16_ARRAY: 4,
INT32_ARRAY: 5,
UINT32_ARRAY: 6,
FLOAT32_ARRAY: 7,
FLOAT64_ARRAY: 8,
BIGINT64_ARRAY: 9,
BIGUINT64_ARRAY: 10
};
createTypedArray(type.INT8_ARRAY);
createTypedArray(type.INT32_ARRAY);
)JS";
OH_JSVM_CreateDataview
在现有的 ArrayBuffer 上创建一个 JavaScript DataView 对象,DataView 对象在底层数据缓冲区上提供类似数组的视图。
cpp部分代码
static int DIFF_VALUE_FOUR = 4;
static int DIFF_VALUE_TWELVE = 12;
// OH_JSVM_CreateDataview的样例方法
static JSVM_Value CreateDataView(JSVM_Env env, JSVM_CallbackInfo info)
{
// 获取js侧传入的两个参数
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
JSVM_Value arrayBuffer = nullptr;
JSVM_Value result = nullptr;
// DataView的字节长度
size_t byteLength = DIFF_VALUE_TWELVE;
// 字节偏移量
size_t byteOffset = DIFF_VALUE_FOUR;
// 获取回调函数的参数信息
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 将参数转换为对象类型
OH_JSVM_CoerceToObject(env, args[0], &arrayBuffer);
// 创建一个数据视图对象,并指定字节长度和字节偏移量
JSVM_Status status = OH_JSVM_CreateDataview(env, byteLength, arrayBuffer, byteOffset, &result);
// 获取DataView的指针和长度信息
uint8_t *data = nullptr;
size_t length = 0;
// 为DataView赋值
for (size_t i = 0; i < length; i++) {
data[i] = static_cast<uint8_t>(i + 1);
}
int32_t infoType;
OH_JSVM_GetValueInt32(env, args[1], &infoType);
size_t returnLength;
JSVM_Value returnArrayBuffer = nullptr;
size_t returnOffset;
enum InfoType { BYTE_LENGTHE, ARRAY_BUFFERE, BYTE_OFFSET };
// 获取dataview信息
OH_JSVM_GetDataviewInfo(env, result, &returnLength, (void **)&data, &returnArrayBuffer, &returnOffset);
JSVM_Value returnResult = nullptr;
switch (infoType) {
case BYTE_LENGTHE:
JSVM_Value len;
OH_JSVM_CreateInt32(env, returnLength, &len);
returnResult = len;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM CreateDataView fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM CreateDataView success, returnLength: %{public}d", returnLength);
}
break;
case ARRAY_BUFFERE:
bool isArraybuffer;
OH_JSVM_IsArraybuffer(env, returnArrayBuffer, &isArraybuffer);
JSVM_Value isArray;
OH_JSVM_GetBoolean(env, isArraybuffer, &isArray);
returnResult = isArray;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM CreateDataView fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM CreateDataView success, isArraybuffer: %{public}d", isArraybuffer);
}
break;
case BYTE_OFFSET:
JSVM_Value offset;
OH_JSVM_CreateInt32(env, returnOffset, &offset);
returnResult = offset;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM CreateDataView fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM CreateDataView success, returnOffset: %{public}d", returnOffset);
}
break;
default:
break;
}
return returnResult;
}
// CreateDataView注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = CreateDataView},
};
static JSVM_CallbackStruct *method = param;
// CreateDataView方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"createDataView", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
let BYTE_LENGTH = 0;
createDataView(new ArrayBuffer(16), BYTE_LENGTH);
let IS_ARRAYBUFFER = 1;
createDataView(new ArrayBuffer(16), IS_ARRAYBUFFER);
let BYTE_OFFSET = 2;
createDataView(new ArrayBuffer(16), BYTE_OFFSET);
)JS";
OH_JSVM_GetArrayLength
返回 Array 对象的长度。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_GetArrayLength的样例方法
static JSVM_Value GetArrayLength(JSVM_Env env, JSVM_CallbackInfo info)
{
size_t argc = 1;
JSVM_Value args[1] = {nullptr};
JSVM_Value result = nullptr;
uint32_t length;
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 检查参数是否为数组
bool isArray = false;
OH_JSVM_IsArray(env, args[0], &isArray);
if (!isArray) {
OH_LOG_INFO(LOG_APP, "JSVM Argument must be an array");
return nullptr;
}
OH_JSVM_GetArrayLength(env, args[0], &length);
// 创建返回值
OH_JSVM_CreateInt32(env, length, &result);
OH_LOG_INFO(LOG_APP, "JSVM length: %{public}d", length);
return result;
}
// GetArrayLength注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = GetArrayLength},
};
static JSVM_CallbackStruct *method = param;
// GetArrayLength方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"getArrayLength", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
let data = [0, 1, 2, 3, 4, 5];
getArrayLength(data);
)JS";
OH_JSVM_GetTypedarrayInfo
获取 TypedArray(类型化数组)对象的信息。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_GetTypedarrayInfo的样例方法
static JSVM_Value GetTypedArrayInfo(JSVM_Env env, JSVM_CallbackInfo info)
{
// 获取并解析参数,第一个参数为需要获得的信息的TypedArray类型数据,第二个参数为需要获得的信息类型的枚举值
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 将第二个参数转为int32类型便于比较
int32_t infoTypeParam;
OH_JSVM_GetValueInt32(env, args[1], &infoTypeParam);
// 定义枚举类型与ArkTS侧枚举类型infoType顺序含义一致
enum InfoType { INFO_TYPE, INFO_LENGTH, INFO_ARRAY_BUFFER, INFO_BYTE_OFFSET };
void *data;
JSVM_TypedarrayType type;
size_t byteOffset, length;
JSVM_Value arrayBuffer = nullptr;
// 调用接口OH_JSVM_GetTypedarrayInfo获得TypedArray类型数据的信息
JSVM_Status status = OH_JSVM_GetTypedarrayInfo(env, args[0], &type, &length, &data, &arrayBuffer, &byteOffset);
JSVM_Value result = nullptr;
// 根据属性名,返回TypedArray对应的属性值
switch (infoTypeParam) {
case INFO_TYPE:
// 如果传入的参数是int8类型的TypedArray数据,它的类型(type)为JSVM_INT8_ARRAY
JSVM_Value int8_type;
OH_JSVM_GetBoolean(env, type == JSVM_INT8_ARRAY, &int8_type);
result = int8_type;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetTypedArrayInfo fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetTypedArrayInfo success, JSVM_INT8_ARRAY: %{public}d", type == JSVM_INT8_ARRAY);
}
break;
case INFO_LENGTH:
// TypedArray中的元素数
JSVM_Value jsvmLength;
OH_JSVM_CreateInt32(env, length, &jsvmLength);
result = jsvmLength;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetTypedArrayInfo fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetTypedArrayInfo success, length: %{public}d", length);
}
break;
case INFO_BYTE_OFFSET:
// TypedArray数组的第一个元素所在的基础原生数组中的字节偏移量
JSVM_Value jsvmOffset;
OH_JSVM_CreateInt32(env, byteOffset, &jsvmOffset);
result = jsvmOffset;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetTypedArrayInfo fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetTypedArrayInfo success, byteOffset: %{public}d", byteOffset);
}
break;
case INFO_ARRAY_BUFFER:
// TypedArray下的ArrayBuffer
bool isArrayBuffer;
OH_JSVM_IsArraybuffer(env, arrayBuffer, &isArrayBuffer);
JSVM_Value isArray;
OH_JSVM_GetBoolean(env, isArrayBuffer, &isArray);
result = isArray;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetTypedArrayInfo fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetTypedArrayInfo success, isArrayBuffer: %{public}d", isArrayBuffer);
}
break;
default:
break;
}
return result;
}
// GetTypedArrayInfo注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = GetTypedArrayInfo},
};
static JSVM_CallbackStruct *method = param;
// GetTypedArrayInfo方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"getTypedArrayInfo", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
// is JSVM_INT8_ARRAY
getTypedArrayInfo(new Int8Array(3), 0);
// length
getTypedArrayInfo(new Int8Array(5), 1);
// is_arraybuffer
getTypedArrayInfo(new Int8Array(5), 2);
// byteoffset
getTypedArrayInfo(new Int8Array(1), 3);
)JS";
OH_JSVM_GetDataviewInfo
获取 Dataview 对象的信息。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_GetDataviewInfo的样例方法
static JSVM_Value GetDataViewInfo(JSVM_Env env, JSVM_CallbackInfo info)
{
// 获取并解析参数,第一个参数为需要获得的信息的DataView类型数据,第二个参数为需要获得的信息类型的枚举值
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 将第二个参数转为int32类型的数字
int32_t infoType;
OH_JSVM_GetValueInt32(env, args[1], &infoType);
size_t byteLength;
void *data;
JSVM_Value arrayBuffer = nullptr;
size_t byteOffset;
// 定义枚举类型与ArkTS侧枚举类型infoType顺序含义一致
enum infoTypeEnum { BYTE_LENGTHE, ARRAY_BUFFERE, BYTE_OFFSET };
// 获取dataview信息
JSVM_Status status = OH_JSVM_GetDataviewInfo(env, args[0], &byteLength, &data, &arrayBuffer, &byteOffset);
JSVM_Value result = nullptr;
switch (infoType) {
case BYTE_LENGTHE:
// 返回查询DataView的长度
JSVM_Value len;
OH_JSVM_CreateInt32(env, byteLength, &len);
result = len;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetDataViewInfo fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetDataViewInfo success, byteLength: %{public}d", byteLength);
}
break;
case ARRAY_BUFFERE:
// 判断DataView的Info里的arraybuffer是否为arraybuffer
bool isArrayBuffer;
OH_JSVM_IsArraybuffer(env, arrayBuffer, &isArrayBuffer);
JSVM_Value isArray;
OH_JSVM_GetBoolean(env, isArrayBuffer, &isArray);
result = isArray;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetDataViewInfo fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetDataViewInfo success, isArrayBuffer: %{public}d", isArrayBuffer);
}
break;
case BYTE_OFFSET:
// 返回查询DataView的偏移量
JSVM_Value offset;
OH_JSVM_CreateInt32(env, byteOffset, &offset);
result = offset;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetDataViewInfo fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetDataViewInfo success, byteOffset: %{public}d", byteOffset);
}
break;
default:
break;
}
return result;
}
// GetDataViewInfo注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = GetDataViewInfo},
};
static JSVM_CallbackStruct *method = param;
// GetDataViewInfo方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"getDataViewInfo", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
// bytelength
getDataViewInfo(new DataView(new Int8Array([2,5]).buffer), 0);
// is arraybuffer
let data = 'a';
let isarraybuffer = 1;
getDataViewInfo(data, isarraybuffer);
// is arraybuffer
data = new DataView(new Int8Array([2,5,3]).buffer);
isarraybuffer = 1;
getDataViewInfo(data, isarraybuffer);
// byte_offset
data = new DataView(new Int8Array([2,5,3]).buffer);
isarraybuffer = 2;
getDataViewInfo(data, isarraybuffer);
)JS";
OH_JSVM_IsArray
判断一个 JavaScript 对象是否为 Array 类型对象。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_IsArray的样例方法
static JSVM_Value IsArray(JSVM_Env env, JSVM_CallbackInfo info)
{
size_t argc = 1;
JSVM_Value args[1] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
bool result = false;
JSVM_Status status = OH_JSVM_IsArray(env, args[0], &result);
JSVM_Value returnValue = nullptr;
OH_JSVM_GetBoolean(env, result, &returnValue);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM IsArray fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM IsArray success, IsArray: %{public}d", result);
}
return returnValue;
}
// IsArray注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = IsArray},
};
static JSVM_CallbackStruct *method = param;
// IsArray方法别名,TS侧调用
static JSVM_PropertyDescriptor descriptor[] = {
{"isArray", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
let data = [1, 2, 3, 4, 5];
isArray(data);
)JS";
OH_JSVM_SetElement
在给定对象的指定索引处设置元素。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_SetElement的样例方法
static int DIFF_VALUE_THREE = 3;
static JSVM_Value SetElement(JSVM_Env env, JSVM_CallbackInfo info) {
size_t argc = DIFF_VALUE_THREE;
JSVM_Value args[3] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
int32_t index = 0;
OH_JSVM_GetValueInt32(env, args[1], &index);
JSVM_Status status = OH_JSVM_SetElement(env, args[0], index, args[2]);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM SetElement fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM SetElement success");
}
return args[0];
}
// SetElement注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = SetElement},
};
static JSVM_CallbackStruct *method = param;
// SetElement方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"setElement", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
setElement(3);
)JS";
OH_JSVM_GetElement
获取给定对象指定索引处的元素。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_GetElement的样例方法
static JSVM_Value GetElement(JSVM_Env env, JSVM_CallbackInfo info) {
// 获取js侧传入的两个参数
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 获取请求元素的索引值
uint32_t index;
OH_JSVM_GetValueUint32(env, args[1], &index);
// 获取请求索引位置的元素值并存储在result中
JSVM_Value result = nullptr;
JSVM_Status status = OH_JSVM_GetElement(env, args[0], index, &result);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetElement fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetElement success");
}
return result;
}
// GetElement注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = GetElement},
};
static JSVM_CallbackStruct *method = param;
// GetElement方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"getElement", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
let arr = [10, 'hello', null, true];
getElement(arr, 3);
)JS";
OH_JSVM_HasElement
若给定对象的指定索引处拥有属性,获取该元素。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_HasElement的样例方法
static JSVM_Value HasElement(JSVM_Env env, JSVM_CallbackInfo info)
{
// 获取js侧传入的两个参数
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 获取要判断的元素的索引
uint32_t index;
OH_JSVM_GetValueUint32(env, args[1], &index);
// 判断指定索引位置的元素是否存在
bool hasElement = true;
JSVM_Status status = OH_JSVM_HasElement(env, args[0], index, &hasElement);
// 将boolean结果转换为JSVM_Value并返回
JSVM_Value result = nullptr;
OH_JSVM_GetBoolean(env, hasElement, &result);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM hasElement fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM hasElement: %{public}d", hasElement);
}
return result;
}
// HasElement注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = HasElement},
};
static JSVM_CallbackStruct *method = param;
// HasElement方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"hasElement", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
let arr = [10, 'hello', null, true];
hasElement(arr, 0);
hasElement(arr, 4);
)JS";
OH_JSVM_DeleteElement
尝试删除给定对象的指定索引处的元素。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_DeleteElement的样例方法
static JSVM_Value DeleteElement(JSVM_Env env, JSVM_CallbackInfo info) {
// 获取js侧传入的两个参数
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 获取要删除的元素的索引
uint32_t index;
OH_JSVM_GetValueUint32(env, args[1], &index);
// 尝试删除请求索引位置的元素
bool deleted = true;
JSVM_Status status = OH_JSVM_DeleteElement(env, args[0], index, &deleted);
// 将boolean结果转换为JSVM_Value并返回
JSVM_Value result = nullptr;
OH_JSVM_GetBoolean(env, deleted, &result);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM DeleteElement fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM DeleteElement: %{public}d", deleted);
}
return result;
}
// DeleteElement注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = DeleteElement},
};
static JSVM_CallbackStruct *method = param;
// DeleteElement方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"deleteElement", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
let arr = [10, 'hello', null, true];
deleteElement(arr, 0);
)JS";
OH_JSVM_IsDataview
判断一个 JavaScript 对象是否为 Dataview类型对象。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_IsDataview的样例方法
static JSVM_Value IsDataView(JSVM_Env env, JSVM_CallbackInfo info) {
size_t argc = 1;
JSVM_Value args[1] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 调用OH_JSVM_IsDataview接口判断给定入参是否为DataView数据。
bool result = false;
JSVM_Status status = OH_JSVM_IsDataview(env, args[0], &result);
JSVM_Value isDateView = nullptr;
OH_JSVM_GetBoolean(env, result, &isDateView);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM IsDataView fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM IsDataView: %{public}d", result);
}
return isDateView;
}
// IsDataView注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = IsDataView},
};
static JSVM_CallbackStruct *method = param;
// IsDataView方法别名,TS侧调用
static JSVM_PropertyDescriptor descriptor[] = {
{"isDataView", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
let buffer = new ArrayBuffer(16);
let dataView = new DataView(buffer);
isDataView(dataView);
)JS";
OH_JSVM_IsTypedarray
判断一个 JavaScript 对象是否为 Typedarray 类型对象。
cpp 部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_IsTypedarray的样例方法
static JSVM_Value IsTypedarray(JSVM_Env env, JSVM_CallbackInfo info) {
size_t argc = 1;
JSVM_Value args[1] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
bool result = false;
JSVM_Status status = OH_JSVM_IsTypedarray(env, args[0], &result);
JSVM_Value isTypedArray = nullptr;
OH_JSVM_GetBoolean(env, result, &isTypedArray);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM IsTypedarray fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM IsTypedarray: %{public}d", result);
}
return isTypedArray;
}
// IsTypedarray注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = IsTypedarray},
};
static JSVM_CallbackStruct *method = param;
// IsTypedarray方法别名,TS侧调用
static JSVM_PropertyDescriptor descriptor[] = {
{"isTypedarray", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char *srcCallNative = R"JS(
isTypedarray(new Uint16Array([1, 2, 3, 4]));
)JS";