异步功能仅在定位ECMAScript 2015或更高版本时可用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了异步功能仅在定位ECMAScript 2015或更高版本时可用相关的知识,希望对你有一定的参考价值。

我希望能够使用async关键字,但我希望我的typescript编译成es5代码,以便我的代码可以在普通人浏览器中运行。当我尝试在visual studio代码中使用async时,我收到此错误。

异步功能仅在定位ECMAScript 2015或更高版本时可用。

我认为针对es6意味着编译打字稿的输出javascript将是es6,而es6在大多数浏览器上都不起作用了吗?

这是我的tsconfig.json

{
  "compilerOptions": {
    "target": "es5",
    "module": "system",
    "moduleResolution": "node",
    "lib": ["es2015", "dom"],
    "sourceMap": true,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "removeComments": false,
    "noImplicitAny": true,
    "outDir":"js/app/",
    "typeRoots": [
      "./node_modules/@types"
    ]
  },
    "exclude": [
    "node_modules",
    "app/test"
  ]
}

我想知道lib字段是否可以使它工作,因为它说"es2015"但它没有。

我也想也许core-js垫片可以使async可用,但我只在我的index.html中包含这样的垫片:

<script src="node_modules/core-js/client/shim.min.js"></script>

所以我认为它不会在编译时提供async。有没有更好的方法来导入core-js?

如何使async可用,但也没有我的代码无法在大多数浏览器上运行?

答案

ECMAScript6在大多数主流浏览器中都受支持。

正如@loganfsmyth对此答案的评论所述,

请记住,“大多数主流浏览器”仍然只能覆盖一小部分用户群。

Firefox

Chrome

From Safari's website

ES6完全支持ECMAScript 2015标准,也称为ES6,将这一主要的JavaScript演变带到了macOS和ios上的Safari。

你将不得不改变,

"target": "es5",

"target": "es6",

ES6目标中的TypeScript 1.7 async / await支持(Node v4 +)TypeScript现在支持对ES6生成器具有本机支持的引擎的异步函数,例如:节点v4及更高版本。异步函数以async关键字为前缀; await挂起执行,直到满足异步函数返回promise,并从返回的Promise中解除值。

以上是关于异步功能仅在定位ECMAScript 2015或更高版本时可用的主要内容,如果未能解决你的问题,请参考以下文章

es2017新特性

错误 TS1056:访问器仅在 gulp-typescript 中以 ECMAScript 5 为目标时可用

如何仅在 ES2015 中生成从 0 到 n 的数字范围?

JavaScript ES6功能概述(ECMAScript 6和ES2015 +)

ES6 阮一峰阅读学习

GTM 中的错误:此语言功能仅支持 ECMASCRIPT_2015 或更好的模式:const 声明