类型查询:jQuery风格的类型操作 2021-11-10 默认分类 暂无评论 2077 次阅读 data:image/s3,"s3://crabby-images/4a659/4a659ecd11fff2b9744ee5794a62aa6725f50fbc" alt="" 将元组转换为对象 在这篇文章中,我们介绍了一种新的方法来创建TypeScript中使用的类型,它允许我们使用JavaScript内联来轻松生成复杂的类型。 我们使用的语言是TypeType(The Art of Type Programming)。 ## 简介 在`TypeType v0.0.30`中,我们有一个新的类型。`ContextType`,例如: data:image/s3,"s3://crabby-images/1d8ff/1d8ff24917a169e301dbc290c35d5cd32b678ba4" alt="" 类型中的总和 这里我们使用语法"```...```"来插入JavaScript代码,并以这种方式实现`globalContext.sum`。 data:image/s3,"s3://crabby-images/9f535/9f5354a51f7590e6c0eb90893f3581b768a5c58f" alt="" 类型背景 "sum "接收`TypeType`中的值和返回`AST`,结果是。 data:image/s3,"s3://crabby-images/79b20/79b2097a50879ba9aa652471d29d2359ccd86c78" alt="" 累计金额 这个例子[点击这里](http://www.guobacai.com/index.php/go/url-211-1/ "点击这里") ## 类型查询 一旦我们可以执行外部的`JavaScript`代码,我们就可以实现`libs`来制造一些类似于魔法的东西。 我们知道,将联合类型转换为元组类型是很难的,然而,在`ContextType`中这是微不足道的。 data:image/s3,"s3://crabby-images/c5303/c53037f06830c7a220b5d56013f69462c6f7844e" alt="" 联合到类型中的元组 这里我们使用`"$.use "`来访问类型变量 "input "的AST,并在`JavaScript`中把它转换成`TupleType`。 data:image/s3,"s3://crabby-images/52ce1/52ce1d80ab2bffe1a27144c33f2c12258e6644f9" alt="" 类型查询扩展 我们使用 "query.install "来添加这个扩展到`$:TypeQuery`对象,灵感来自`jQuery`。 输出结果是: data:image/s3,"s3://crabby-images/3f5b9/3f5b9c6ddc92545872cf0c13c592cc5fdecb5f7e" alt="" 并联到TS中的元组 顺序保持原样,实际上,你可以按照你的要求重新排序。 `TypeQuery`的扩展性很好,你可以做这样的事情: data:image/s3,"s3://crabby-images/bbeb8/bbeb8c773b364a1274b95c8c3e7cf853538bd0c8" alt="" 并得到结果: data:image/s3,"s3://crabby-images/e339d/e339d5de32cdb0c24410c518992b019c6b309723" alt="" 上面的例子可以在以下内容中找到。 [typetype-template/blob/main/src/type-query-extension.ts](http://www.guobacai.com/index.php/go/url-211-2/ "typetype-template/blob/main/src/type-query-extension.ts") [mistlog/typetype-template/blob/main/src/type-query-basic.ts](http://www.guobacai.com/index.php/go/url-211-3/ "mistlog/typetype-template/blob/main/src/type-query-basic.ts") ## 类型测试 我们可以从`Type Runtime`获得`AST`和`type-in-string`,因此我们可以用普通的`jest`来测试类型。 data:image/s3,"s3://crabby-images/0c551/0c55153db276aa1cbbe91adde3657cb6fd7a95c7" alt="" 参考资料:[mistlog/typetype-template/blob/main/test/type-runtime.test.ts](http://www.guobacai.com/index.php/go/url-211-4/ "mistlog/typetype-template/blob/main/test/type-runtime.test.ts") ## 实施 代码可以在这里找到:[mistlog/type-query](http://www.guobacai.com/index.php/go/url-211-5/ "mistlog/type-query") 对于快速启动:[mistlog/typetype-template]( http://www.guobacai.com/index.php/go/url-211-6/ "mistlog/typetype-template") 标签: javascript, TypeScript, 类型, 代码, 元组, blob, ast
评论已关闭