
在JSDoc中定义具有固定属性和任意额外属性的对象类型是一个常见的需求,它允许开发者为数据结构指定核心字段,同时保留未来扩展的灵活性。本文旨在解决JSDoc中如何描述一种对象类型,该类型既包含一组强制性的固定属性,又允许添加任意数量的其他未预定义属性。我们将探讨两种主要方法:使用@property {*} [key: value]直接标记任意属性,以及通过结合@typedef和Object.
在J*aScript开发中,我们经常需要定义数据结构。例如,一个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,除了已知的固定属性外,对象还可以拥有任意数量的其他属性。
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的交集类型(&)和 Object.
/**
* @typedef {object} UserBase
* @property {string} name - 用户名
* @property {number} age - 用户年龄
*/
/**
* @typedef {Object.<string, string>} AdditionalProperties -
键为字符串,值为字符串的额外属性
*/
/**
* @typedef {UserBase & AdditionalProperties} UserWithDetails - 包含固定属性和额外属性的用户详情
*/
/**
* @type {UserWithDetails}
*/
const tom = {
name: "cx",
age: 25,
from: "sh", // 不再报错
to: "bj", // 不再报错
};这种方法允许你对额外属性的值类型进行更细粒度的控制:
在JSDoc中定义具有固定属性和任意额外属性的对象类型时,选择合适的方法取决于你的具体需求和对类型严格性的要求:
*选择 `@property {} [key: value]`**:
选择交集类型与 Object.
整体而言,结合交集类型和 Object.
以上就是在JSDoc中定义具有固定属性和任意额外属性的对象类型的详细内容,更多请关注其它相关文章!
相关文章:
Safari浏览器输入栏卡顿如何解决 Safari搜索建议与缓存清理
Archive of Our Own官网直达 AO3最新可用地址一览
必由学官网首页入口 必由学教师网页版登录指南
随机参数递归函数的基准调用次数与时间复杂度探究
Win11如何开启讲述人功能 Win11屏幕阅读器(讲述人)开启与关闭【教程】
在J*a中如何隐藏复杂性_使用门面模式组织对象交互
Descript怎样用AI剪辑自动去噪_Descript用AI剪辑自动去噪【自动降噪】
在J*aScript中复现SciPy的B样条拟合与求值:关键考量
汽水音乐网页版使用入口_汽水音乐电脑版播放指南
sublime如何只显示或隐藏特定类型文件_sublime侧边栏文件过滤
如何仅使用CSS更改登录界面背景图像图标的颜色
如何让 composer 信任自签名的 HTTPS 证书源?
期待已久:小米17 Ultra、小米首款NAS本月登场
谷歌浏览器怎么给标签页静音_Chrome标签静音快捷操作
网易大神怎么保存别人动态的图片_网易大神动态图片保存方法
抖音网页版企业服务中心登录入口_抖音网页版企业登录平台
怎样在Excel中做仪表盘_Excel仪表盘设计与关键指标展示方法
win11专注助手在哪 Win11免打扰模式设置与自动化规则【指南】
如何提高微信支付的安全性_微信支付安全防护与设置建议
神经网络二分类模型训练异常:高损失与完美验证准确率的排查与修正
Go语言实现持久化与原子性文件存储的教程
豆包手机助手发布技术预览版:直接嵌入手机系统!努比亚样机发售
优化MinIO list_objects_v2 操作的性能瓶颈与最佳实践
极速漫画官方主页网址 极速漫画漫画在线浏览官网链接
J*aScript井字棋(Tic-Tac-Toe)核心交互逻辑实现教程
Shopware订单对象中获取产品自定义字段的正确方法
解决移动端滚动问题的overflow属性应用指南
解决PHP会话Cookie在跨域请求中不保留的问题
ACG动漫视频网入口 ACG动漫*免费正版观看地址
AO3网页版合集入口 Archive of Our Own同人作品浏览指南
漫蛙漫画网页端入口 漫蛙2官方正版漫画站点
俄罗斯浏览器官网直达链接 俄罗斯浏览器最新在线入口导航
自定义Bag-of-Words实现:处理带负号的词汇权重
Excel中VLOOKUP的第四个参数是干什么用的_Excel VLOOKUP第四参数作用解析
J*aScript对象创建方式_J*aScript设计模式应用
Golang并发任务中错误如何聚合_Golang goroutine error收集方式
Golang如何实现微服务鉴权与权限控制_Golang微服务鉴权与权限管理实践
在WordPress中通过REST API获取BasicAuth保护的远程文章
极兔快递快件信息查询系统 极兔快递官网运单号追踪
抖音创作助手登录入口_抖音创作辅助工具官网直达
Composer的 COMPOSER_PROCESS_TIMEOUT 配置项有什么用_解决因执行时间过长而失败的Composer脚本
将PCM16音频数据转换为W*并编码为Base64教程
css子元素高度不一致导致布局错位怎么办_使用align-items:stretch解决高度差异
QQ邮箱网页版邮箱入口 QQ邮箱官方登录平台
学习通网页版快速入口 学习通官网网页版直接打开
AO3最新镜像入口 Archive of Our Own官方平台访问
WooCommerce后台产品编辑页:获取分类ID并实现角色权限控制
Spring Boot内嵌服务器与J*a EE全栈特性:选择与部署策略
解决Flask中Quill编辑器内容提交失败及TypeError的指南
微信网页版官方快速登录入口 微信网页版网页版账号直达