为了账号安全,请及时绑定邮箱和手机立即绑定

树结构的打字接口

树结构的打字接口

幕布斯6054654 2022-08-04 16:54:53
我想为树结构定义一个接口。每个节点可以有零个或多个子节点:export interface TreeNode {  children?: Array<TreeNode>;}我已经为s实现了一个遍历函数。TreeNodeexport function traverseTree(treeData: Array<TreeNode> | TreeNode, callback: (treeNode: any) => any) {  // implementation omitted}我想测试它。代码如下:const treeData = [  {    name: "root_1",    children: [      {        name: "child_1",        children: [          {            name: "grandchild_1"          },          {            name: "grandchild_2"          }        ]      }    ]  },  {    name: "root_2",    children: []  }];const traversingHistory = [];const callback = (treeNode: any) => {  traversingHistory.push(treeNode.name);}traverseTree(treeData, callback);但是,编译失败,因为 类型的参数不能应用于 。treeDatatraverseTree我不想向接口添加属性,因为树节点可以具有动态属性。如何修改接口以接受更通用的类型?nameTreeNodeTreeNode
查看完整描述

3 回答

?
慕斯709654

TA贡献1840条经验 获得超5个赞

您可能遇到的错误是:


对象文本可能仅指定已知属性,并且“name”在类型中不存在


如果要允许其他键,则必须是该类型的一部分。您可以使用索引签名执行此操作:


export interface TreeNode {

  [key: string]: any // type for unknown keys.

  children?: TreeNode[] // type for a known property.

}


查看完整回答
反对 回复 2022-08-04
?
qq_笑_17

TA贡献1818条经验 获得超7个赞

我想使用a更适合:generic[key: string]: any

export type Tree<T> = T & {
  children?: T[];
}

保留我们想要构建树的类型的必需字段和可选字段:对于此问题,Item 是:。ItemTree<Item>{ name: string }


查看完整回答
反对 回复 2022-08-04
?
饮歌长啸

TA贡献1951条经验 获得超3个赞

尝试将此联合类型与 :object

type TreeNode = {
    children?: Array<TreeNode>;
} & object;


查看完整回答
反对 回复 2022-08-04
  • 3 回答
  • 0 关注
  • 138 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号