(将是)TypeScript与ES6的兼容性(ECMAScript 2015)

hgo*_*ebl 5 javascript typescript ecmascript-6

我认为TypeScript(基本上)是ECMAScript 6(又名2015),附带了类型注释.

我的TypeScript编译器(1.6.2)抱怨以下代码:

if (calc.distance > Number.EPSILON) {
    ...
}
Run Code Online (Sandbox Code Playgroud)

错误TS2339:'NumberConstructor'类型中不存在属性'EPSILON'.

是否存在打字问题或者TypeScript(还)是否真的是ES6的超集?

我还没有尝试过这样的前沿之类的东西Map,WeakMap,承诺,发电机,...

TypeScript只是稍微落后于ES6,还是走向另一个方向?我应该通过Babel运行TypeScript编译器输出吗?

刚开始使用TypeScript,我不想背错马.

Pal*_*leo 5

为什么Number.EPSILON目标 ES3 和 ES5 不存在

我认为 TypeScript(基本上)是带有额外类型注释的 ECMAScript 6(又名 2015)。

TypeScript 是带有附加注释的 ECMAScript。ES6 中的一些特性,如类、其余参数、lambdas、for oflet,在 ES5 或 ES3 中有干净的等效代码,编译器可以为这些目标生成一些代码。但是新的 API 需要 polyfill,并且编译器不会添加任何运行时库(与 Babel 或 Traceur 不同)。

您的代码使用目标 ES6 进行编译。

对于目标 ES3 和 ES5,您必须:1/ 加载一个 polyfill(像这个)和 2/ 添加 TypeScript 编译器的定义。

查找 ES6 API 的 TypeScript 定义

所以,你需要找到定义。这是查找 ES6 API 定义的提示。

ES6 API 的所有定义都已在编译器中定义。我们可以使用它们。在您的节点目录中,打开文件lib/node_modules/typescript/lib/lib.es6.d.ts. 然后,搜索EPSILON。你会发现一个界面NumberConstructor。下面是它的代码(TS 1.6.2):

interface NumberConstructor {
    /**
      * The value of Number.EPSILON is the difference between 1 and the smallest value greater than 1
      * that is representable as a Number value, which is approximately:
      * 2.2204460492503130808472633361816 x 10???16.
      */
    EPSILON: number;

    /**
      * Returns true if passed value is finite.
      * Unlike the global isFininte, Number.isFinite doesn't forcibly convert the parameter to a
      * number. Only finite values of the type number, result in true.
      * @param number A numeric value.
      */
    isFinite(number: number): boolean;

    /**
      * Returns true if the value passed is an integer, false otherwise.
      * @param number A numeric value.
      */
    isInteger(number: number): boolean;

    /**
      * Returns a Boolean value that indicates whether a value is the reserved value NaN (not a
      * number). Unlike the global isNaN(), Number.isNaN() doesn't forcefully convert the parameter
      * to a number. Only values of the type number, that are also NaN, result in true.
      * @param number A numeric value.
      */
    isNaN(number: number): boolean;

    /**
      * Returns true if the value passed is a safe integer.
      * @param number A numeric value.
      */
    isSafeInteger(number: number): boolean;

    /**
      * The value of the largest integer n such that n and n + 1 are both exactly representable as
      * a Number value.
      * The value of Number.MIN_SAFE_INTEGER is 9007199254740991 2^53 ? 1.
      */
    MAX_SAFE_INTEGER: number;

    /**
      * The value of the smallest integer n such that n and n ? 1 are both exactly representable as
      * a Number value.
      * The value of Number.MIN_SAFE_INTEGER is ?9007199254740991 (?(2^53 ? 1)).
      */
    MIN_SAFE_INTEGER: number;

    /**
      * Converts a string to a floating-point number.
      * @param string A string that contains a floating-point number.
      */
    parseFloat(string: string): number;

    /**
      * Converts A string to an integer.
      * @param s A string to convert into a number.
      * @param radix A value between 2 and 36 that specifies the base of the number in numString.
      * If this argument is not supplied, strings with a prefix of '0x' are considered hexadecimal.
      * All other strings are considered decimal.
      */
    parseInt(string: string, radix?: number): number;
}
Run Code Online (Sandbox Code Playgroud)

只需在您的项目中添加此代码。