Saltar al contenido principal

@babel/plugin-transform-async-to-generator

Traducción Beta No Oficial

Esta página fue traducida por PageTurner AI (beta). No está respaldada oficialmente por el proyecto. ¿Encontraste un error? Reportar problema →

información

Este plugin está incluido en @babel/preset-env, en ES2017

En Babel 7, transform-async-to-module-method se integró en este plugin

Ejemplo

Entrada

JavaScript
async function foo() {
await bar();
}

Salida

JavaScript
var _asyncToGenerator = function (fn) {
...
};
var foo = _asyncToGenerator(function* () {
yield bar();
});

Salida con opciones

Convierte funciones asíncronas en una corrutina de Bluebird (advertencias)

JavaScript
var Bluebird = require("bluebird");

var foo = Bluebird.coroutine(function*() {
yield bar();
});

Instalación

npm install --save-dev @babel/plugin-transform-async-to-generator

Uso

Mediante un archivo de configuración (Recomendado)

Sin opciones:

babel.config.json
{
"plugins": ["@babel/plugin-transform-async-to-generator"]
}

Con opciones:

babel.config.json
{
"plugins": [
[
"@babel/plugin-transform-async-to-generator",
{
"module": "bluebird",
"method": "coroutine"
}
]
]
}

Mediante la CLI

Shell
babel --plugins @babel/plugin-transform-async-to-generator script.js

Mediante la API de Node

JavaScript
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-transform-async-to-generator"],
});

Advertencias

Error en tiempo de ejecución de Bluebird con valores no promesa

Al usar await con valores que no son promesas, Bluebird lanzará "Error: A value was yielded that could not be treated as a promise". Dado que Babel no puede manejar automáticamente este error en tiempo de ejecución, debes transformarlo manualmente en una promesa.

async function foo() {
- await 42;
+ await Promise.resolve(42);
}

Referencias