news 2026/1/11 17:49:24

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/1/9 18:19:37

大模型自动化时代来临,Open-AutoGLM将如何重塑AI工程链路?

第一章&#xff1a;大模型自动化时代来临&#xff0c;Open-AutoGLM将如何重塑AI工程链路&#xff1f;随着大语言模型&#xff08;LLM&#xff09;在自然语言理解、代码生成和多模态任务中展现出强大能力&#xff0c;AI工程的开发范式正经历深刻变革。传统AI项目依赖大量人工调参…

作者头像 李华
网站建设 2026/1/10 2:09:17

校园外卖点餐|基于java + vue校园外卖点餐系统(源码+数据库+文档)

校园外卖点餐 目录 基于springboot vue校园外卖点餐系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue校园外卖点餐系统 一、前言 博主介绍&…

作者头像 李华
网站建设 2026/1/8 19:03:18

精通Gemini API:从零到一的异步AI开发实战

精通Gemini API&#xff1a;从零到一的异步AI开发实战 【免费下载链接】Gemini-API ✨ An elegant async Python wrapper for Google Gemini web app 项目地址: https://gitcode.com/gh_mirrors/gem/Gemini-API 想要在AI开发领域快速上手&#xff1f;Gemini API正是你需…

作者头像 李华
网站建设 2026/1/10 18:14:40

全面掌握ArchUnit:Java架构验证的终极指南

全面掌握ArchUnit&#xff1a;Java架构验证的终极指南 【免费下载链接】ArchUnit A Java architecture test library, to specify and assert architecture rules in plain Java 项目地址: https://gitcode.com/gh_mirrors/ar/ArchUnit 项目核心价值 ArchUnit是一款专为…

作者头像 李华
网站建设 2026/1/8 19:03:15

UAI Editor:AI驱动的文档创作终极解决方案

UAI Editor&#xff1a;AI驱动的文档创作终极解决方案 【免费下载链接】uai-editor UAI Editor 是一个现代 UI 风格、面向 AI 的强大的个人&团队文档。开箱即用&#xff0c;支持Vue、React、Layui、Angular 等几乎任何前端框架。 项目地址: https://gitcode.com/uai-team…

作者头像 李华