刺激控制器中带有计算名称变量的 Webpack encore 构建错误

Webpack encore build error with computed name variable in stimulus controller

我在 webpack 版本 5.40.0

在我的一个脚本中,我使用计算出的变量名与 async/await /import.. 在刺激控制器中做出承诺

它运行良好。 今天,当我更新我的依赖项并将 webpack 添加到最新版本:5.52.1 时,构建失败并在第一个 [ 这一行中出现错误:this.['module' + datagridshortName[i]]

'Syntax Error: Unexpected token'在括号上。

那么现在如何在webpack encore中使用计算名称变量呢??

我刚回到 webpack 5.40 并且代码可以正常工作。

感谢您的解释/帮助:)

我的代码:

    async createDatagridSource(){
   
    let datagridScName = [];
    let datagridshortName = [];
    Object.entries(this.datagrid).forEach(entry => {
        const [key, value] = entry;
        datagridScName.push(value.controllerNameSc);
        datagridshortName.push(value.shortName);
    });

    for (let i = 0; i < datagridshortName.length; i++) {
        this.['module' + datagridshortName[i]] = await import('../js/datagrid_config/' + datagridScName[i] + '_config');
        this.module=this.['module' + datagridshortName[i]];
        this.datafields=this.module.datafields();

        this.columns=this.module.columns();
        this.columngroups=this.module.columngroups();
        this.config=this.module.config();

        //source des données initiales
        this.['source' + datagridshortName[i]] ={
            datafields:this.datafields,
            data: { "viewArchives" : this.viewArchives,...this.sourceOtherdata(datagridshortName[i])},
            url: this.datagrid[datagridshortName[i]].urlInit,

            //********************************
            id: 'data',
            type: "POST",
            datatype: "json",
            root: 'data',
        }
        //adaptater de la source
        this.['dataAdapter' + datagridshortName[i]] = new $.jqx.dataAdapter(this.['source' + datagridshortName[i]]);
    }

    //renvoi l'identifiant du premier datagrid
    return datagridshortName[0];
}

Package.json

"devDependencies": {
"@symfony/webpack-encore": "^1.5.0",
"autoprefixer": "^10.2.6",
"core-js": "^3.15.1",
"file-loader": "^6.2.0",
"postcss": "^8.3.5",
"postcss-loader": "^5.3.0",
"precss": "^4.0.0",
"regenerator-runtime": "^0.13.7",
"sass": "^1.35.1",
"sass-loader": " ^12.1.0",
"webpack": "5.52.1",
"webpack-notifier": "^1.13.0"

},

所以这只是一个拼写错误:

this.['module' + datagridshortName[i]] => 这['module' + datagridshortName[i]]

只需删除 .没关系。

Explanation (感谢 Lyzard kyng)