web-dev-qa-db-fra.com

en utilisant async / wait avec une erreur de lancement de configuration webpack-simple: RegeneratorRuntime non défini

J'utilise un modèle webpack-simple avec les configurations suivantes:

package.json

{
  "name": "vue-wp-simple",
  "description": "A Vue.js project",
  "version": "1.0.0",
  "author": "v",
  "private": true,
  "scripts": {
    "dev": "webpack-dev-server --inline --hot",
    "build": "cross-env NODE_ENV=production webpack --progress --hide-modules"
  },
  "dependencies": {
    "vue": "^2.3.3",
    "vue-router": "^2.7.0",

  },
  "devDependencies": {
    "babel-core": "^6.0.0",
    "babel-loader": "^6.0.0",
    "babel-preset-env": "^1.5.1",
    "babel-preset-es2015": "^6.24.1",
    "babel-preset-stage-2": "^6.24.1",
    "cross-env": "^3.0.0",
    "css-loader": "^0.25.0",
    "file-loader": "^0.9.0",
    "style-loader": "^0.18.2",
    "stylus": "^0.54.5",
    "stylus-loader": "^3.0.1",
    "vue-loader": "^12.1.0",
    "vue-template-compiler": "^2.3.3",
    "webpack": "^2.6.1",
    "webpack-dev-server": "^2.4.5"
  }
} 

. babelrc

{
  "presets": [
    ["env", { "modules": false }],
  ]
} 

ci-dessous est la façon dont j'utilise async/wait dans mon composant

async mounted(){
            //this.$store.dispatch('loadImg', this.details.imgUrl).then((img) => {
                //this.drawImage(img);    
            //});

            var result = await this.loadImg();
            console.log(result);
        },
        methods:{
            async loadImg(){
                return new Promise((resolve, reject) => {
                    setTimeout(() => {
                        resolve('yeah async await works!');
                    }, 2000);
                });
            }, 
         }

Mais lorsque j'exécute l'application, j'obtiens l'erreur: ReferenceError: régénérateurRuntime n'est pas défini et même le composant n'est pas affiché

18
boomerboy

Pour utiliser wait/async , vous devrez installer quelques dépendances Babel. Cela fonctionne avec le projet Vuejs -

npm install --save-dev babel-polyfill
npm install --save-dev babel-plugin-transform-regenerator

Une fois installé, vous devrez modifier votre fichier . Babelrc pour utiliser le plugin comme suit -

{
    "plugins": ["transform-regenerator"]
}

et aussi votre webpack.config.js fichier pour utiliser le régénérateur comme suit -

require("babel-polyfill");

module.exports = {
  entry: ["babel-polyfill", "./app.js"]
};

Apportez les modifications nécessaires en fonction de la structure de votre projet et du nom de fichier, etc.

22
Sohail

Pour utiliser async & wait, vous devez ajouter 2 plugins à votre configuration babel: https://babeljs.io/docs/plugins/transform-async-to-generator/ et https: //babeljs.io/docs/plugins/syntax-async-functions/

4
Anh Nguyen

La solution de Sohail fonctionne. J'avais une fonction asynchrone, qui a fini par jeter l'erreur ...

Pour être sûr, j'ai utilisé la vue-cli pour construire mon projet. En tant que tel, j'ai une vue.config.js, qui lors de la compilation injecte du contenu dans webpack.config.

(Des informations à ce sujet peuvent être trouvées ici )

Donc, dans vue.config.js, j'ai ce qui suit:

module.exports = {
configureWebpack: {
    entry: ['@babel/polyfill', './src/main.ts'],
    plugins: [
    ]
},
chainWebpack: config => {
    config.resolve.alias.set('@image', path.resolve(__dirname, 'public/img'));
    config.resolve.alias.set('@dev', path.resolve(__dirname, 'dev-server'));
},

}

Ensuite, dans babel.config.js, j'ai ceci:

module.exports = {
 presets: [
   '@babel/env',
 ],
 plugins: [
  "transform-regenerator"
 ],
}

J'espère que ça aide!

0
AdamJSim