news 2026/6/10 16:26:41

Property Descriptor

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Property Descriptor

属性描述符(Property Descriptor)

Napi::Object可通过其DefinePropertyDefineProperties方法为自身分配属性,这两个方法均接收PropertyDescriptor(属性描述符)作为参数。Napi::PropertyDescriptor可包含值或函数,这些值 / 函数会被分配给目标Napi::Object。请注意:单个Napi::PropertyDescriptor类实例只能包含一个值,或最多两个函数;属性描述符仅能通过该类的AccessorFunctionValue方法创建 —— 这些方法都会返回一个新的Napi::PropertyDescriptor静态实例。

示例

#include <napi.h> using namespace Napi; Value TestGetter(const CallbackInfo& info) { return Boolean::New(info.Env(), testValue); } void TestSetter(const CallbackInfo& info) { testValue = info[0].As<Boolean>(); } Value TestFunction(const CallbackInfo& info) { return Boolean::New(info.Env(), true); } void Init(Env env) { // 创建一个对象 Object obj = Object::New(env); // 只读访问器 PropertyDescriptor pd1 = PropertyDescriptor::Accessor<TestGetter>("pd1"); // 读写访问器 PropertyDescriptor pd2 = PropertyDescriptor::Accessor<TestGetter, TestSetter>("pd2"); // 函数属性 PropertyDescriptor pd3 = PropertyDescriptor::Function(env, "function", TestFunction); // 值属性 Boolean true_bool = Boolean::New(env, true); PropertyDescriptor pd4 = PropertyDescriptor::Value("boolean value", Napi::Boolean::New(env, true), napi_writable); // 为对象批量定义属性 obj.DefineProperties({pd1, pd2, pd3, pd4}); }

类型(Types)

PropertyDescriptor::GetterCallback

using GetterCallback = Napi::Value (*)(const Napi::CallbackInfo& info);

这是作为模板参数传递给PropertyDescriptor::Accessor获取器函数签名

PropertyDescriptor::SetterCallback

using SetterCallback = void (*)(const Napi::CallbackInfo& info);

这是作为模板参数传递给PropertyDescriptor::Accessor设置器函数签名

方法(Methods)

构造函数(Constructor)

Napi::PropertyDescriptor::PropertyDescriptor (napi_property_descriptor desc);
  • [in] desc:用于创建新属性描述符的napi_property_descriptor实例。

Accessor(访问器)

template <Napi::PropertyDescriptor::GetterCallback Getter> static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (___ name, napi_property_attributes attributes = napi_default, void* data = nullptr);
  • [模板参数] Getter:获取器函数。
  • [in] attributes:获取器函数的特性标志(可选)。
  • [in] data:任意类型的数据指针,默认值为空指针。

返回包含只读属性的属性描述符。

属性名称支持以下类型:

  • const char*
  • const std::string &
  • napi_value value
  • Napi::Name
template < Napi::PropertyDescriptor::GetterCallback Getter, Napi::PropertyDescriptor::SetterCallback Setter> static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (___ name, napi_property_attributes attributes = napi_default, void* data = nullptr);
  • [模板参数] Getter:获取器函数。
  • [模板参数] Setter:设置器函数。
  • [in] attributes:获取器函数的特性标志(可选)。
  • [in] data:任意类型的数据指针,默认值为空指针。

返回包含读写属性的属性描述符。

属性名称支持以下类型:

  • const char*
  • const std::string &
  • napi_value value
  • Napi::Name
static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (___ name, Getter getter, napi_property_attributes attributes = napi_default, void *data = nullptr);
  • [in] name:获取器函数的名称。
  • [in] getter:获取器函数。
  • [in] attributes:获取器函数的特性标志(可选)。
  • [in] data:任意类型的数据指针,默认值为空指针。

返回包含单个函数的属性描述符。

属性名称支持以下类型:

  • const char*
  • const std::string &
  • napi_value value
  • Napi::Name

⚠️ 注意:该签名已废弃,使用会导致内存泄漏。

static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor ( Napi::Env env, Napi::Object object, ___ name, Getter getter, napi_property_attributes attributes = napi_default, void *data = nullptr);
  • [in] env:创建该访问器的运行环境。
  • [in] object:要定义访问器的目标对象。
  • [in] name:获取器函数的名称。
  • [in] getter:获取器函数。
  • [in] attributes:获取器函数的特性标志(可选)。
  • [in] data:任意类型的数据指针,默认值为空指针。

返回包含 Getter 访问器的Napi::PropertyDescriptor

属性名称支持以下类型:

  • const char*
  • const std::string &
  • Napi::Name
static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor (___ name, Getter getter, Setter setter, napi_property_attributes attributes = napi_default, void *data = nullptr);
  • [in] name:获取器和设置器函数的名称。
  • [in] getter:获取器函数。
  • [in] setter:设置器函数。
  • [in] attributes:获取器函数的特性标志(可选)。
  • [in] data:任意类型的数据指针,默认值为空指针。

返回包含 Getter 和 Setter 函数的属性描述符。

属性名称支持以下类型:

  • const char*
  • const std::string &
  • napi_value value
  • Napi::Name

⚠️ 注意:该签名已废弃,使用会导致内存泄漏。

static Napi::PropertyDescriptor Napi::PropertyDescriptor::Accessor ( Napi::Env env, Napi::Object object, ___ name, Getter getter, Setter setter, napi_property_attributes attributes = napi_default, void *data = nullptr);
  • [in] env:创建该访问器的运行环境。
  • [in] object:要定义访问器的目标对象。
  • [in] name:获取器和设置器函数的名称。
  • [in] getter:获取器函数。
  • [in] setter:设置器函数。
  • [in] attributes:获取器函数的特性标志(可选)。
  • [in] data:任意类型的数据指针,默认值为空指针。

返回包含 Getter 和 Setter 函数的Napi::PropertyDescriptor

属性名称支持以下类型:

  • const char*
  • const std::string &
  • Napi::Name

Function(函数)

static Napi::PropertyDescriptor Napi::PropertyDescriptor::Function (___ name, Callable cb, napi_property_attributes attributes = napi_default, void *data = nullptr);
  • [in] name:可调用函数的名称。
  • [in] cb:目标函数。
  • [in] attributes:函数的特性标志(可选)。
  • [in] data:任意类型的数据指针,默认值为空指针。

返回包含可调用Napi::Function的属性描述符。

属性名称支持以下类型:

  • const char*
  • const std::string &
  • napi_value value
  • Napi::Name

⚠️ 注意:该签名已废弃,使用会导致内存泄漏。

static Napi::PropertyDescriptor Napi::PropertyDescriptor::Function ( Napi::Env env, ___ name, Callable cb, napi_property_attributes attributes = napi_default, void *data = nullptr);
  • [in] env:创建该函数属性的运行环境。
  • [in] name:可调用函数的名称。
  • [in] cb:目标函数。
  • [in] attributes:函数的特性标志(可选)。
  • [in] data:任意类型的数据指针,默认值为空指针。

返回包含可调用Napi::FunctionNapi::PropertyDescriptor

属性名称支持以下类型:

  • const char*
  • const std::string &
  • Napi::Name

Value(值)

static Napi::PropertyDescriptor Napi::PropertyDescriptor::Value (___ name, napi_value value, napi_property_attributes attributes = napi_default);

属性名称支持以下类型:

  • const char*
  • const std::string &
  • napi_value value
  • Napi::Name

相关信息(Related Information)

napi_property_attributes

napi_property_attributes是一组标志,用于告知 JavaScript 该属性应具备的访问权限。可选标志如下:

  • napi_default(默认权限)
  • napi_writable(可写)
  • napi_enumerable(可枚举)
  • napi_configurable(可配置)

如需了解这些标志及napi_property_attributes的更多细节,请参考此处。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 9:07:59

EASE 4.0:专业音响设计软件的终极解决方案

EASE 4.0&#xff1a;专业音响设计软件的终极解决方案 【免费下载链接】EASE4.0安装包 EASE 4.0是一款专业的音响和声学设计软件&#xff0c;专为音响工程师和声学设计师打造&#xff0c;提供精准的声场模拟与分析功能。软件集成了丰富的设计工具&#xff0c;支持详细的声场分析…

作者头像 李华
网站建设 2026/6/10 9:00:55

【资深AI工程师私藏】:autodl平台部署Open-AutoGLM的6大核心步骤

第一章&#xff1a;Shell脚本的基本语法和命令Shell脚本是Linux和Unix系统中自动化任务的核心工具&#xff0c;它通过解释执行一系列命令实现复杂操作。编写Shell脚本时&#xff0c;通常以“shebang”开头&#xff0c;用于指定解释器路径。脚本的起始声明 所有Shell脚本应以如下…

作者头像 李华
网站建设 2026/6/10 9:03:41

4.2 传统观测器与抗扰技术

4.2 传统观测器与抗扰技术 在永磁同步电机(PMSM)高性能控制系统中,为实现对转矩、转速及位置的精确闭环控制,必须获取准确的状态反馈信息。物理传感器(如电流传感器、转速编码器)虽能直接测量,但存在成本、可靠性及安装限制。此外,系统运行中不可避免的负载扰动、模型…

作者头像 李华
网站建设 2026/6/10 10:41:59

终极指南:如何用legendary轻松管理Epic游戏库

终极指南&#xff1a;如何用legendary轻松管理Epic游戏库 【免费下载链接】legendary Legendary - A free and open-source replacement for the Epic Games Launcher 项目地址: https://gitcode.com/gh_mirrors/le/legendary 还在为Epic Games启动器缓慢的下载速度而烦…

作者头像 李华