ts-metatype

define type in runtime by typescipt

Usage no npm install needed!

<script type="module">
  import tsMetatype from 'https://cdn.skypack.dev/ts-metatype';
</script>

README

Typescript的运行时类型系统

将运行时类型定义,校验和编辑时类型提示检测联系起来,基于ts-metacode实现
主要功能(打勾表示已经实现):

  • 定义运行时类型
  • 在开发时提供等同于Typescript类型定义的提示功能(类型生成)
  • 使用typedef对value进行校验
    • validate函数提供的结果可以被编辑器用作类型跟踪
  • 支持可扩展的类型定义(自定义class)
  • 扩展类型定义
    • 支持在类型定义中添加默认值
    • 支持在类型定义中添加Example表(kv对),并支持使用函数直接获取
    • 支持动态对类型定义添加Example值,并保持类型定义的功能不变
    • 对添加Example后或Default后的类型定义,支持将添加的值的信息(如key名)添加到类型定义中,并提供编辑时支持
    • 对不同模态的类型定义实现兼容

Example

以下为已实现功能的测试

静态类型获取

// 测试部分
const tp = {
  a: Object,
  b: String,
  c:Number,
  h: {
    c: Object
  },
  k: multi([Object, Array, String]),
  // default this declare a type of (number|object)[]
  s: [Object, Number],
  sss:ANY
};


type MyType = TypeOf<typeof tp>;

// 此时MyType的类型和直接使用interface或type关键字定义的类型一致,支持编译器提示

编译时数据类型检测

const tt = {
  a: Object,
  b: String,
  c: {
    d:Number
  }
}
//! 以下代码会报错 d的类型错误,应该为number
const v = value(tt, {
  a: {t:""},
  b: "",
  c: {
    d:"s"
  }
})

运行时类型校验

const tt = {
  a: Object,
  b: String,
  c: {
    d:Number
  }
}
//以下代码得到true ,可尝试修改其中数据类型,查看校验结果
console.log(validate(tt, {
  a: {t:""},
  b: "",
  c: {
    d:100
  }
}))

问题

  • object类型拦截问题,所有不在基本类型表中的类型会被映射为object,限制了可扩展性,这有赖于ts-metacode包的更新改进映射功能
  • ANY类型的定义问题,可能存在隐患({}别名产生的问题)