转发 TypeScript基础入门之Javascript文件类型检查(三)git
继续上篇文章【TypeScript基础入门之Javascript文件类型检查(二)】github
下面的列表概述了使用JSDoc注释在JavaScript文件中提供类型信息时当前支持的构造。数组
请注意,尚不支持下面未明确列出的任何标记(例如@async)。promise
含义一般与usejsdoc.org上给出的标记含义相同或超集。下面的代码描述了这些差别,并给出了每一个标记的一些示例用法。dom
@typeasync
您能够使用”@type“标记并引用类型名称(原语,在TypeScript声明中定义,或在JSDoc”@typedef“标记中)。您能够使用任何Typescript类型和大多数JSDoc类型。函数
/** * @type {string} */ var s; /** @type {Window} */ var win; /** @type {PromiseLike<string>} */ var promisedString; // You can specify an HTML Element with DOM properties /** @type {HTMLElement} */ var myElement = document.querySelector(selector); element.dataset.myData = '';
@type能够指定联合类型 - 例如,某些东西能够是字符串或布尔值。ui
/** * @type {(string | boolean)} */ var sb;
请注意,括号对于联合类型是可选的。this
/** * @type {string | boolean} */ var sb;
您能够使用各类语法指定数组类型:spa
/** @type {number[]} */ var ns; /** @type {Array.<number>} */ var nds; /** @type {Array<number>} */ var nas;
您还能够指定对象文字类型。例如,具备属性’a’(字符串)和’b’(数字)的对象使用如下语法:
/** @type {{ a: string, b: number }} */ var var9;
您能够使用标准JSDoc语法或Typescript语法,使用字符串和数字索引签名指定相似地图和相似数组的对象。
/** * A map-like object that maps arbitrary `string` properties to `number`s. * * @type {Object.<string, number>} */ var stringToNumber; /** @type {Object.<number, object>} */ var arrayLike;
前两种类型等同于Typescript类型{ [x: string]: number }和{ [x: number]: any }。编译器理解这两种语法。
您能够使用Typescript或Closure语法指定函数类型:
/** @type {function(string, boolean): number} Closure syntax */ var sbn; /** @type {(s: string, b: boolean) => number} Typescript syntax */ var sbn2;
或者您能够使用未指定的函数类型:
/** @type {Function} */ var fn7; /** @type {function} */ var fn6;
Closure的其余类型也有效:
/** * @type {*} - can be 'any' type */ var star; /** * @type {?} - unknown type (same as 'any') */ var question;
类型转换
Typescript借用了Closure的强制语法。这容许您经过在任何带括号的表达式以前添加@type标记将类型转换为其余类型。
/** * @type {number | string} */ var numberOrString = Math.random() < 0.5 ? "hello" : 100; var typeAssertedNumber = /** @type {number} */ (numberOrString)
导入类型
您还能够使用导入类型从其余文件导入声明。此语法是特定于Typescript的,与JSDoc标准不一样:
/** * @param p { import("./a").Pet } */ function walk(p) { console.log(`Walking ${p.name}...`); }
导入类型也能够在类型别名声明中使用:
/** * @typedef Pet { import("./a").Pet } */ /** * @type {Pet} */ var myPet; myPet.name;
若是你不知道类型,或者它有一个使人讨厌的大型类型,能够使用import类型从模块中获取值的类型:
/** * @type {typeof import("./a").x } */ var x = require("./a").x;
未完待续…