刺激控制器中带有计算名称变量的 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)
我在 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)