往期鸿蒙5.0全套实战文章必看:(文中附带全栈鸿蒙5.0学习资料)
使用JSVM-API接口进行object相关开发
简介
使用JSVM-API接口进行object相关开发,处理JavaScript对象的基本操作的功能,例如创建对象、获取原型、冻结和密封对象,检查对象的类型等。这些操作是在处理JavaScript对象时非常常见的,提供了一种与JavaScript对象交互的方式。
基本概念
在JSVM接口开发中,经常需要定义和操作对象。例如,创建一个API接口,该接口接受一个对象作为输入参数,对该对象执行某些操作,并返回一个结果对象。在这个过程中,需要确保接口的定义清晰、规范,并且与对象的属性和方法相兼容。
- 接口(API):接口定义了组件之间的交互协议,包括输入参数、输出结果以及可能的错误处理。通过接口,组件可以相互调用和交换数据,而无需了解对方的内部实现细节。
- 对象(Object):在JavaScript,对象是一种复合数据类型,允许存储多个不同类型的值作为一个单独的实体。对象是属性和方法的集合。属性是与对象相关联的值,而方法则是对象可以执行的操作。
接口说明
接口 | 功能说明 |
---|---|
OH_JSVM_GetPrototype | 获取给定JavaScript对象的原型。 |
OH_JSVM_CreateObject | 创建一个默认的JavaScript Object对象。 |
OH_JSVM_ObjectFreeze | 冻结给定的对象,防止向其添加新属性,删除现有属性,防止更改现有属性的可枚举性、可配置性或可写性,并防止更改现有属性的值。 |
OH_JSVM_ObjectSeal | 密封给定的对象。这可以防止向其添加新属性,以及将所有现有属性标记为不可配置。 |
OH_JSVM_Typeof | 返回JavaScript对象的类型。 |
OH_JSVM_Instanceof | 判断一个对象是否是某个构造函数的实例。 |
OH_JSVM_TypeTagObject | 将type_tag指针的值与JavaScript对象或外部对象相关联。 |
OH_JSVM_CheckObjectTypeTag | 检查给定的类型标签是否与对象上的类型标签匹配。 |
OH_JSVM_CreateSymbol | 根据给定的描述符创建一个Symbol对象。 |
OH_JSVM_SymbolFor | 在全局注册表中搜索具有给定描述的现有Symbol,如果该Symbol已经存在,它将被返回,否则将在注册表中创建一个新Symbol。 |
OH_JSVM_CreateExternal | 创建一个包装了外部指针的JavaScript对象。 |
OH_JSVM_GetValueExternal | 获取先前传递给OH_JSVM_CreateExternal的外部数据指针。 |
使用示例
JSVM-API接口开发流程参考使用JSVM-API实现JS与C/C++语言交互开发流程,本文仅对接口对应C++及ArkTS相关代码进行展示。
OH_JSVM_GetPrototype
获取给定JavaScript对象的原型。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// GetPrototype注册回调
// OH_JSVM_GetPrototype的样例方法
static JSVM_Value GetPrototype(JSVM_Env env, JSVM_CallbackInfo info)
{
size_t argc = 1;
JSVM_Value argv[1] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, argv, nullptr, nullptr);
JSVM_Value result{nullptr};
JSVM_Status status = OH_JSVM_GetPrototype(env, argv[0], &result);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetPrototype fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetPrototype success");
}
return result;
}
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = GetPrototype},
};
static JSVM_CallbackStruct *method = param;
// GetPrototype方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"getPrototype", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(const myObject = {};
const proto = getPrototype(myObject);
console.log(proto === Object.prototype);)JS";
预期的输出结果
JSVM GetPrototype success
OH_JSVM_CreateObject
创建一个默认的JavaScript Object对象。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_CreateObject的样例方法
static JSVM_Value CreateObject(JSVM_Env env, JSVM_CallbackInfo info)
{
JSVM_Value object = nullptr;
// 创建一个空对象
JSVM_Status status = OH_JSVM_CreateObject(env, &object);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM CreateObject fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM CreateObject success");
}
// 设置对象的属性
JSVM_Value name = nullptr;
// 设置属性名为 "name"
OH_JSVM_CreateStringUtf8(env, "name", JSVM_AUTO_LENGTH, &name);
JSVM_Value value = nullptr;
// 设置属性值为 "Hello from N-API!"
OH_JSVM_CreateStringUtf8(env, "Hello OH_JSVM_CreateObject!", JSVM_AUTO_LENGTH, &value);
// 将属性设置到对象上
OH_JSVM_SetProperty(env, object, name, value);
return object;
}
// CreateObject注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = CreateObject},
};
static JSVM_CallbackStruct *method = param;
// CreateObject方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"createObject", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(createObject())JS";
预期的输出结果
JSVM CreateObject success
OH_JSVM_ObjectFreeze
冻结给定的对象,防止向其添加新属性,删除现有属性,防止更改现有属性的可枚举性、可配置性或可写性,并防止更改现有属性的值。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_ObjectFreeze的样例方法
static JSVM_Value ObjectFreeze(JSVM_Env env, JSVM_CallbackInfo info)
{
// 接受一个JavaScript侧传入的object
size_t argc = 1;
JSVM_Value argv[1] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, argv, nullptr, nullptr);
// 调用接口OH_JSVM_ObjectFreeze将传入的object冻结
JSVM_Status status = OH_JSVM_ObjectFreeze(env, argv[0]);
if (status == JSVM_OK) {
OH_LOG_INFO(LOG_APP, "Test JSVM OH_JSVM_ObjectFreeze success");
}
// 测试冻结后的对象中属性能否修改
JSVM_Value value = nullptr;
OH_JSVM_CreateInt32(env, 111111, &value);
OH_JSVM_SetNamedProperty(env, argv[0], "data", value);
// 将冻结后修改过的属性返回JavaScript侧
return argv[0];
}
// ObjectFreeze注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = ObjectFreeze},
};
static JSVM_CallbackStruct *method = param;
// ObjectFreeze方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"objectFreeze", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(let obj = { data: 55, message: "hello world"};
objectFreeze(obj))JS";
预期的输出结果
Test JSVM OH_JSVM_ObjectFreeze success
OH_JSVM_ObjectSeal
密封给定的对象。这可以防止向其添加新属性,以及将所有现有属性标记为不可配置。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_ObjectSeal的样例方法
static JSVM_Value ObjectSeal(JSVM_Env env, JSVM_CallbackInfo info)
{
// 接受一个JavaScript侧传入的object
size_t argc = 1;
JSVM_Value argv[1] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, argv, nullptr, nullptr);
// 调用接口OH_JSVM_ObjectSeal将传入的object封闭,使其无法添加新的属性
JSVM_Status status = OH_JSVM_ObjectSeal(env, argv[0]);
if (status == JSVM_OK) {
OH_LOG_INFO(LOG_APP, "Test JSVM OH_JSVM_ObjectSeal success");
}
// 检查封闭后的对象中属性能否修改、删除、新增
// 封闭后对象修改
JSVM_Value changeValue = nullptr;
OH_JSVM_CreateInt32(env, 111111, &changeValue);
OH_JSVM_SetNamedProperty(env, argv[0], "data", changeValue);
// 封闭后对象删除
JSVM_Value deleteProperty = nullptr;
OH_JSVM_CreateStringUtf8(env, "message", JSVM_AUTO_LENGTH, &deleteProperty);
bool result = false;
OH_JSVM_DeleteProperty(env, argv[0], deleteProperty, &result);
if (result) {
OH_LOG_INFO(LOG_APP, "Test JSVM OH_JSVM_ObjectSeal failed");
}
// 封闭后对象新增
JSVM_Value addValue = nullptr;
OH_JSVM_CreateStringUtf8(env, "addValue", JSVM_AUTO_LENGTH, &addValue);
OH_JSVM_SetNamedProperty(env, argv[0], "newProperty", addValue);
// 将封闭后改动过的对象返回JavaScript侧
return argv[0];
}
// ObjectSeal注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = ObjectSeal},
};
static JSVM_CallbackStruct *method = param;
// ObjectSeal方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"objectSeal", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS( let obj = { data: 55, message: "hello world"};
objectSeal(obj))JS";
预期的输出结果
Test JSVM OH_JSVM_ObjectSeal success
OH_JSVM_Typeof
返回JavaScript对象的类型。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_Typeof的样例方法
static JSVM_Value GetTypeof(JSVM_Env env, JSVM_CallbackInfo info) {
size_t argc = 1;
JSVM_Value args[1] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
JSVM_ValueType valueType;
OH_JSVM_Typeof(env, args[0], &valueType);
JSVM_Value type = nullptr;
switch (valueType) {
case JSVM_UNDEFINED:
OH_LOG_INFO(LOG_APP, "JSVM Input type is undefined");
OH_JSVM_CreateStringUtf8(env, "Input type is undefined", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_NULL:
OH_LOG_INFO(LOG_APP, "JSVM Input type is null");
OH_JSVM_CreateStringUtf8(env, "Input type is null", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_BOOLEAN:
OH_LOG_INFO(LOG_APP, "JSVM Input type is boolean");
OH_JSVM_CreateStringUtf8(env, "Input type is boolean", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_NUMBER:
OH_LOG_INFO(LOG_APP, "JSVM Input type is number");
OH_JSVM_CreateStringUtf8(env, "Input type is number", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_STRING:
OH_LOG_INFO(LOG_APP, "JSVM Input type is string");
OH_JSVM_CreateStringUtf8(env, "Input type is string", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_SYMBOL:
OH_LOG_INFO(LOG_APP, "JSVM Input type is symbol");
OH_JSVM_CreateStringUtf8(env, "Input type is symbol", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_OBJECT:
OH_LOG_INFO(LOG_APP, "JSVM Input type is object");
OH_JSVM_CreateStringUtf8(env, "Input type is object", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_FUNCTION:
OH_LOG_INFO(LOG_APP, "JSVM Input type is function");
OH_JSVM_CreateStringUtf8(env, "Input type is function", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_EXTERNAL:
OH_LOG_INFO(LOG_APP, "JSVM Input type is external");
OH_JSVM_CreateStringUtf8(env, "Input type is external", JSVM_AUTO_LENGTH, &type);
break;
case JSVM_BIGINT:
OH_LOG_INFO(LOG_APP, "JSVM Input type is bigint");
OH_JSVM_CreateStringUtf8(env, "Input type is bigint", JSVM_AUTO_LENGTH, &type);
break;
default:
OH_LOG_INFO(LOG_APP, "JSVM Input type does not match any");
OH_JSVM_CreateStringUtf8(env, " ", JSVM_AUTO_LENGTH, &type);
break;
}
return type;
}
// GetTypeof注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = GetTypeof},
};
static JSVM_CallbackStruct *method = param;
// GetTypeof方法别名,TS侧调用
static JSVM_PropertyDescriptor descriptor[] = {
{"getTypeof", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(getTypeof(true);)JS";
预期的输出结果
JSVM Input type is boolean
OH_JSVM_Instanceof
判断一个对象是否是某个构造函数的实例。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_Instanceof的样例方法
static JSVM_Value InstanceOf(JSVM_Env env, JSVM_CallbackInfo info)
{
// 获取两个JavaScript侧传入的参数
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
bool result = false;
JSVM_Status status = OH_JSVM_Instanceof(env, args[0], args[1], &result);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM InstanceOf fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM InstanceOf:%{public}d", result);
}
JSVM_Value returnValue = nullptr;
OH_JSVM_GetBoolean(env, result, &returnValue);
return returnValue;
}
// InstanceOf注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = InstanceOf},
};
static JSVM_CallbackStruct *method = param;
// InstanceOf方法别名,TS侧调用
static JSVM_PropertyDescriptor descriptor[] = {
{"instanceOf", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(class Person {
name;
age;
constructor(name, age) {
this.name = name;
this.age = age;
}
}
instanceOf(new Person('Alice', 30), Person);
;)JS";
预期的输出结果
JSVM InstanceOf:1
OH_JSVM_TypeTagObject
使用类型标签type_tag来标记JavaScript对象,后续可以更精确地识别JavaScript对象。
OH_JSVM_CheckObjectTypeTag
检查给定的类型标签是否与对象上的类型标签匹配。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
#define NUMBERINT_FOUR 4
// 定义一个静态常量JSVM_TypeTag数组存储类型标签
static const JSVM_TypeTag TagsData[NUMBERINT_FOUR] = {
{0x9e4b2449547061b3, 0x33999f8a6516c499},
{0x1d55a794c53a726d, 0x43633f509f9c944e},
{0, 0}, // 用于表示无标签或默认标签
{0x6a971439f5b2e5d7, 0x531dc28a7e5317c0},
};
// OH_JSVM_TypeTagObject的样例方法
static JSVM_Value SetTypeTagToObject(JSVM_Env env, JSVM_CallbackInfo info)
{
// 获取两个JavaScript侧传入的参数
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 获取索引数字转换为JSVM_Value
int32_t index = 0;
OH_JSVM_GetValueInt32(env, args[1], &index);
// 给参数(对象)设置类型标签
JSVM_Status status = OH_JSVM_TypeTagObject(env, args[0], &TagsData[index]);
// 将bool结果转换为JSVM_Value并返回
JSVM_Value result = nullptr;
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM SetTypeTagToObject fail");
OH_JSVM_GetBoolean(env, false, &result);
} else {
OH_LOG_INFO(LOG_APP, "JSVM SetTypeTagToObject success");
OH_JSVM_GetBoolean(env, true, &result);
}
return result;
}
// OH_JSVM_CheckObjectTypeTag的样例方法
static JSVM_Value CheckObjectTypeTag(JSVM_Env env, JSVM_CallbackInfo info)
{
// 获取两个JavaScript侧传入的参数
size_t argc = 2;
JSVM_Value args[2] = {nullptr};
OH_JSVM_GetCbInfo(env, info, &argc, args, nullptr, nullptr);
// 获取索引数字转换为JSVM_Value
int32_t index = 0;
OH_JSVM_GetValueInt32(env, args[1], &index);
// 检查对象的类型标签
bool checkResult = false;
JSVM_Status status = OH_JSVM_CheckObjectTypeTag(env, args[0], &TagsData[index], &checkResult);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM SetTypeTagToObject fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM SetTypeTagToObject:%{public}d", checkResult);
}
// 将bool结果转换为JSVM_Value并返回
JSVM_Value checked = nullptr;
OH_JSVM_GetBoolean(env, checkResult, &checked);
return checked;
}
// SetTypeTagToObject,CheckObjectTypeTag注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = SetTypeTagToObject},
{.data = nullptr, .callback = CheckObjectTypeTag},
};
static JSVM_CallbackStruct *method = param;
// SetTypeTagToObject,CheckObjectTypeTag方法别名,TS侧调用
static JSVM_PropertyDescriptor descriptor[] = {
{"setTypeTagToObject", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
{"checkObjectTypeTag", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(
class Obj {
data;
message;
}
let obj= { data: 0, message: "hello world"};
setTypeTagToObject(obj, 0);
checkObjectTypeTag(obj,0);)JS";
预期的输出结果
JSVM SetTypeTagToObject success
JSVM SetTypeTagToObject:1
OH_JSVM_CreateExternal
创建一个包装了外部指针的JavaScript对象。
注意:JavaScript对象被垃圾回收时,包装的外部指针指向的内容不被GC直接管理,仅调用传入的第三个参数对应的函数(如果传入时不为nullptr)。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_CreateExternal的样例方法
static JSVM_Value CreateExternal(JSVM_Env env, JSVM_CallbackInfo info)
{
size_t dataSize = 10;
void *data = malloc(dataSize);
if (data == nullptr) {
OH_LOG_ERROR(LOG_APP, "JSVM Failed to malloc.");
return nullptr;
}
memset(data, 0, dataSize);
const char* testStr = "test";
JSVM_Value external = nullptr;
JSVM_Status status = OH_JSVM_CreateExternal(
env, data, [](JSVM_Env env, void *data, void *hint) {free(data);}, (void *)testStr, &external);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM Failed to create external data, status:%{public}d.", status);
free(data);
data = nullptr;
return nullptr;
} else {
OH_LOG_INFO(LOG_APP, "JSVM CreateExternal success");
}
return external;
}
// CreateExternal注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = CreateExternal},
};
static JSVM_CallbackStruct *method = param;
// CreateExternal方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"createExternal", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(createExternal())JS";
预期的输出结果
JSVM CreateExternal success
OH_JSVM_GetValueExternal
OH_JSVM_CreateExternal可以创建包装自定义的C/C++对象并将其公开给JavaScript代码,而OH_JSVM_GetValueExternal就是用来获得OH_JSVM_CreateExternal所包装的外部对象的指针。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_GetValueExternal的样例方法
static JSVM_Value GetValueExternal(JSVM_Env env, JSVM_CallbackInfo info)
{
static int data = 0x12345;
JSVM_Value externalValue = nullptr;
JSVM_Status status = OH_JSVM_CreateExternal(env, (void*)&data, nullptr, nullptr, &externalValue);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM OH_JSVM_CreateExternal fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM OH_JSVM_CreateExternal success");
}
void *data_value;
status = OH_JSVM_GetValueExternal(env, externalValue, &data_value);
if (status != JSVM_OK) {
OH_LOG_ERROR(LOG_APP, "JSVM GetValueExternal fail");
} else {
OH_LOG_INFO(LOG_APP, "JSVM GetValueExternal success");
}
// 将符号位转化为int类型传出去
JSVM_Value returnValue = nullptr;
int retData = *static_cast<int *>(data_value);
OH_JSVM_CreateInt32(env, retData, &returnValue);
return returnValue;
}
// GetValueExternal注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = GetValueExternal},
};
static JSVM_CallbackStruct *method = param;
// GetValueExternal方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"getValueExternal", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(getValueExternal())JS";
预期的输出结果
JSVM OH_JSVM_CreateExternal success
JSVM GetValueExternal success
OH_JSVM_CreateSymbol
用于创建一个新的Symbol。Symbol是一种特殊的数据类型,用于表示唯一的标识符。与字符串或数字不同,符号的值是唯一的,即使两个符号具有相同的描述,它们也是不相等的。符号通常用作对象属性的键,以确保属性的唯一性。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// OH_JSVM_CreateSymbol的样例方法
static JSVM_Value CreateSymbol(JSVM_Env env, JSVM_CallbackInfo info)
{
JSVM_Value result = nullptr;
const char *des = "only";
OH_JSVM_CreateStringUtf8(env, des, JSVM_AUTO_LENGTH, &result);
JSVM_Value returnSymbol = nullptr;
OH_JSVM_CreateSymbol(env, result, &returnSymbol);
JSVM_ValueType valuetypeSymbol;
OH_JSVM_Typeof(env, returnSymbol, &valuetypeSymbol);
if (valuetypeSymbol == JSVM_SYMBOL) {
OH_LOG_INFO(LOG_APP, "JSVM CreateSymbol Success");
} else {
OH_LOG_INFO(LOG_APP, "JSVM CreateSymbol fail");
}
return returnSymbol;
}
// CreateSymbol注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = CreateSymbol},
};
static JSVM_CallbackStruct *method = param;
// CreateSymbol方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"createSymbol", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(createSymbol())JS";
预期的输出结果
JSVM CreateSymbol Success
OH_JSVM_SymbolFor
在全局注册表中搜索具有给定描述的现有Symbol,如果该Symbol已经存在,它将被返回,否则将在注册表中创建一个新Symbol。
cpp部分代码
// hello.cpp
#include "napi/native_api.h"
#include "ark_runtime/jsvm.h"
#include <hilog/log.h>
// 定义一个常量,用于存储最大字符串长度
static const int MAX_BUFFER_SIZE = 128;
// OH_JSVM_SymbolFor的样例方法
static JSVM_Value SymbolFor(JSVM_Env env, JSVM_CallbackInfo info)
{
JSVM_Value description = nullptr;
OH_JSVM_CreateStringUtf8(env, "test_demo", 9, &description);
char buffer[MAX_BUFFER_SIZE];
size_t bufferSize = MAX_BUFFER_SIZE;
size_t copied = 0;
OH_JSVM_GetValueStringUtf8(env, description, buffer, bufferSize, &copied);
JSVM_Value symbol = nullptr;
OH_JSVM_CreateSymbol(env, description, &symbol);
JSVM_Value result_symbol = nullptr;
JSVM_Status status = OH_JSVM_SymbolFor(env, buffer, copied, &result_symbol);
JSVM_ValueType valuetypeSymbol;
OH_JSVM_Typeof(env, result_symbol, &valuetypeSymbol);
if (valuetypeSymbol == JSVM_SYMBOL && status == JSVM_OK) {
OH_LOG_INFO(LOG_APP, "JSVM OH_JSVM_SymbolFor success");
}
// 返回结果
return result_symbol;
}
// SymbolFor注册回调
static JSVM_CallbackStruct param[] = {
{.data = nullptr, .callback = SymbolFor},
};
static JSVM_CallbackStruct *method = param;
// SymbolFor方法别名,供JS调用
static JSVM_PropertyDescriptor descriptor[] = {
{"symbolFor", nullptr, method++, nullptr, nullptr, nullptr, JSVM_DEFAULT},
};
// 样例测试js
const char* srcCallNative = R"JS(symbolFor())JS";
预期的输出结果
JSVM OH_JSVM_SymbolFor success