0

0

在JSDoc中定义具有固定属性和任意额外属性的对象类型

碧海醫心

碧海醫心

发布时间:2025-11-14 16:29:25

|

695人浏览过

|

来源于php中文网

原创

在jsdoc中定义具有固定属性和任意额外属性的对象类型

在JSDoc中定义具有固定属性和任意额外属性的对象类型是一个常见的需求,它允许开发者为数据结构指定核心字段,同时保留未来扩展的灵活性。本文旨在解决JSDoc中如何描述一种对象类型,该类型既包含一组强制性的固定属性,又允许添加任意数量的其他未预定义属性。我们将探讨两种主要方法:使用@property {*} [key: value]直接标记任意属性,以及通过结合@typedef和Object.创建交集类型,以实现类型定义上的灵活性和精确性。

1. 问题背景与挑战

在JavaScript开发中,我们经常需要定义数据结构。例如,一个User对象可能需要name(字符串)和age(数字)这两个强制属性。然而,在实际应用中,用户数据可能还需要包含其他不确定或可扩展的属性,如from、to等。如果仅使用传统的JSDoc @property 标签来定义固定属性,当添加这些额外属性时,JSDoc类型检查器通常会报告错误,因为它不认识这些未声明的属性。

以下是初始定义可能遇到的问题示例:

/**
 * @typedef {object} User
 * @property {string} name - 用户名
 * @property {number} age - 用户年龄
 */

/**
 * @type {User}
 */
const tom = {
  name: 'cx',
  age: 25,
  from: 'sh', // 错误:属性 'from' 不存在于类型 'User' 中
  to: 'bj',   // 错误:属性 'to' 不存在于类型 'User' 中
};

为了解决这个问题,我们需要一种机制来告诉JSDoc,除了已知的固定属性外,对象还可以拥有任意数量的其他属性。

2. 方法一:使用 @property {*} [key: value] 声明任意属性

JSDoc提供了一种简洁的方式来声明对象可以拥有任意额外属性,即通过 @property 标签结合通配符 * 和 [key: value] 语法。这种方法直接指示JSDoc,除了明确定义的属性外,对象还可以包含任何键值对

示例代码

/**
 * @typedef {Object} User
 * @property {string} name - 用户名 (必填)
 * @property {number} age - 用户年龄 (必填)
 * @property {*} [key: value] - 允许添加的额外属性 (可选)
 */

/**
 * @type {User}
 */
const tom = {
  name: 'cx',
  age: 25,
  from: 'sh', // 不再报错
  to: 'bj',   // 不再报错
};

注意事项

  • * 表示额外属性的值可以是任意类型。这意味着JSDoc不会对这些额外属性的值进行具体的类型检查。如果需要更精确地限制额外属性的值类型(例如,所有额外属性的值都必须是字符串),此方法可能不够精确。
  • 这种方式在某些IDE或类型检查工具中可能不如其他方法提供更强的类型检查提示或智能感知。

3. 方法二:结合交集类型 (&) 和 Object.

第二种方法更为强大和明确,它利用JSDoc的交集类型(&)和 Object. 语法。Object. 是JSDoc中描述一个键为字符串、值为T类型的对象(即一个字典或映射)的标准方式。通过将一个包含固定属性的基础类型与一个表示额外属性集合的字典类型进行合并,可以创建一个既有固定结构又具备灵活扩展性的类型。

示例代码

/**
 * @typedef {object} UserBase
 * @property {string} name - 用户名
 * @property {number} age - 用户年龄
 */

/**
 * @typedef {Object.} AdditionalProperties - 键为字符串,值为字符串的额外属性
 */

/**
 * @typedef {UserBase & AdditionalProperties} UserWithDetails - 包含固定属性和额外属性的用户详情
 */

/**
 * @type {UserWithDetails}
 */
const tom = {
  name: "cx",
  age: 25,
  from: "sh", // 不再报错
  to: "bj",   // 不再报错
};

类型灵活度

这种方法允许你对额外属性的值类型进行更细粒度的控制:

  • Object.: 如果所有额外属性的值都预期是字符串,如上述示例所示。
  • Object.: 如果额外属性的值可以是任意类型,类似于方法一中的 *,但表达更明确。
  • Object.: 如果额外属性的值可以是几种特定类型之一,可以使用联合类型。

优点

  • 明确性: 类型定义更加清晰,明确区分了固定属性和可扩展属性。
  • 类型安全: 能够为额外属性的值提供更精细的类型约束,从而在编译时捕获更多潜在错误。
  • IDE支持: 在支持JSDoc的现代IDE(如VS Code)中,这种方法通常能提供更优秀的类型提示、自动补全和错误检查。

4. 总结与最佳实践

在JSDoc中定义具有固定属性和任意额外属性的对象类型时,选择合适的方法取决于你的具体需求和对类型严格性的要求:

  • *选择 `@property {} [key: value]`**:

    • 当额外属性的类型非常不确定,且你追求最简洁的定义方式时。
    • 当你不需要对这些额外属性的值进行严格的类型检查时。
    • 适用于快速原型开发或对类型约束要求不高的场景。
  • 选择交集类型与 Object.:

    • 当你需要对额外属性的值进行精确的类型约束时(例如,确保所有额外属性的值都是字符串或数字)。
    • 当你希望类型定义更具结构化、可读性和可维护性时。
    • 在大型项目或对代码质量有高要求的场景中,强烈推荐使用此方法,因为它能提供更强的类型安全和更好的开发体验。

整体而言,结合交集类型和 Object. 的方法更符合现代JavaScript类型检查的实践,它在提供灵活性的同时,也保证了类型系统的严谨性。明确的类型定义不仅有助于提高代码的可读性和可维护性,还能有效减少潜在的运行时错误,尤其是在团队协作和长期项目维护中,其优势更为显著。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

556

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

374

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

732

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

477

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

991

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

657

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

552

2023.09.20

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号