gpt4 book ai didi

angular-cli 25.5 模块构建失败

转载 作者:搜寻专家 更新时间:2023-10-30 22:01:01 24 4
gpt4 key购买 nike

问题

在将 angular-cli 从 22.1 更新到 25.5(安装 angular-cli@latest)以及从 angular 2.2.3 更新到 2.3.1 之后,我遇到了这个问题:

ERROR in ./src/app/app.module.ts
Module build failed: TypeError: Cannot read property 'text' of undefined
at IdentifierObject.TokenOrIdentifierObject.getText (~/projects/MyProject/node_modules/typescript/lib/typescript.js:53644:56)
at ~/projects/MyProject/node_modules/@ngtools/webpack/src/loader.js:83:72
at Array.some (native)
at ~/projects/MyProject/node_modules/@ngtools/webpack/src/loader.js:83:32
at Array.filter (native)
at _removeModuleId (~/projects/MyProject/node_modules/@ngtools/webpack/src/loader.js:82:10)
at ~/projects/MyProject/node_modules/@ngtools/webpack/src/loader.js:167:48
@ ./src/main.ts 5:0-45
@ multi main

但我无法弄清楚问题出在哪里,main.ts 看起来很正常:

import './polyfills.ts';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { environment } from './environments/environment';
import { AppModule } from './app/app.module';

if (environment.production) {
enableProdMode();
}

platformBrowserDynamic().bootstrapModule(AppModule);

还有两个其他文件也因与上述完全相同的错误消息而失败,第一个 environment.ts 没有什么特别之处,第二个子模块因添加以下内容而失败:

 @ ./src async
@ ./~/@angular/core/src/linker/system_js_ng_module_factory_loader.js
@ ./~/@angular/core/src/linker.js
@ ./~/@angular/core/src/core.js
@ ./~/@angular/core/index.js
@ ./src/main.ts
@ multi main

节点模块源代码

引用的 typescript.js:53644:56 如下所示:

[53643] TokenOrIdentifierObject.prototype.getText = function (sourceFile) {
[53644] return (sourceFile || this.getSourceFile()).text.substring(this.getStart(), this.getEnd());
[53645] };

loader.js:83:72 & 83:32指的是webpack,这段代码片段:

[078] exports.removeModuleIdOnlyForTesting = removeModuleIdOnlyForTesting;
[...] function _removeModuleId(refactor) {
[...] var sourceFile = refactor.sourceFile;
[...] refactor.findAstNodes(sourceFile, ts.SyntaxKind.ObjectLiteralExpression, true)
[...] .filter(function (node) {
[083] return node.properties.some(function (prop) { return prop.name.getText() == 'moduleId'; });
[...] })
[...] .forEach(function (node) {
[...] var moduleIdProp = node.properties.filter(function (prop, idx) {
[...] return prop.name.getText() == 'moduleId';
[...] })[0];
[...] // get the trailing comma
[...] var moduleIdCommaProp = moduleIdProp.parent.getChildAt(1).getChildren()[1];
[...] refactor.removeNodes(moduleIdProp, moduleIdCommaProp);
[...] });
[093] }

loader.js:167:48

[148] // Super simple TS transpiler loader for testing / isolated usage. does not type check!
[...] function ngcLoader(source) {
[...] this.cacheable();
[...] var cb = this.async();
[...] var sourceFileName = this.resourcePath;
[...] var plugin = this._compilation._ngToolsWebpackPluginInstance;
[...] // We must verify that AotPlugin is an instance of the right class.
[...] if (plugin && plugin instanceof plugin_1.AotPlugin) {
[...] var refactor_2 = new refactor_1.TypeScriptFileRefactor(sourceFileName, plugin.compilerHost, plugin.program);
[...] Promise.resolve()
[...] .then(function () {
[...] if (!plugin.skipCodeGeneration) {
[...] return Promise.resolve()
[...] .then(function () { return _removeDecorators(refactor_2); })
[...] .then(function () { return _replaceBootstrap(plugin, refactor_2); });
[...] }
[...] else {
[...] return Promise.resolve()
[...] .then(function () { return _replaceResources(refactor_2); })
[167] .then(function () { return _removeModuleId(refactor_2); });
[...] }
[169] })
[...] ...

问题

有没有人有同样的问题或者能弄清楚为什么 webpack(?) 会失败 - 或者可以向我解释编译器试图做什么以及为什么会失败?

编辑

angular-cli.json:

{
"project": {
"version": "1.0.0-beta.25.5",
"name": "myproject"
},
"apps": [
{
"root": "src",
"outDir": "dist",
"assets": [
"assets",
"favicon.ico"
],
"index": "index.html",
"main": "main.ts",
"test": "test.ts",
"tsconfig": "tsconfig.json",
"prefix": "app",
"mobile": false,
"styles": [
"assets/css/main.css"
],
"scripts": [
"assets/lib/stomp.min.js"
],
"environments": {
"source": "environments/environment.ts",
"dev": "environments/environment.ts",
"live": "environments/environment.live.ts"
}
}
],
"addons": [],
"packages": [],
"e2e": {
"protractor": {
"config": "./protractor.conf.js"
}
},
"test": {
"karma": {
"config": "./karma.conf.js"
}
},
"defaults": {
"styleExt": "css",
"prefixInterfaces": false,
"inline": {
"style": false,
"template": false
},
"spec": {
"class": false,
"component": true,
"directive": true,
"module": false,
"pipe": true,
"service": true
}
}
}

tsconfig.json:

{
"compilerOptions": {
"baseUrl": "",
"declaration": false,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"lib": [
"es6",
"dom"
],
"mapRoot": "./",
"module": "es6",
"moduleResolution": "node",
"outDir": "../dist/out-tsc",
"sourceMap": true,
"target": "es5",
"typeRoots": [
"../node_modules/@types"
]
},
"files": [
"typings/index.d.ts"
]
}

最佳答案

更新:

正如@stewdebaker 指出的那样:angular-cli: 1.0.0-beta.26 现已发布,似乎可以解决此问题。


正如@stewdebaker 提到的,有一个类似的问题 Build error in angular2 frontend using angular-cli - 解决方案是恢复到 angular-cli: 1.0.0-beta.21

另见 https://github.com/angular/angular-cli/issues/4072angular-cli 问题跟踪器中获取有关该问题的更多信息。


我无法修复我的项目,也无法恢复到我以前的 angular-cli 版本 1.0.0-beta.22-1(我没有在 Stack Overflow 上看到其他问题,否则我可能会尝试恢复到 1.0.0-beta.21)。

由于某些原因,在更新到 1.0.0-beta.25.5 之前,ng serve 命令可以正常工作,但在恢复到 1.0.0-beta.22 之后-1 它仍然会出现与更新后相同的错误。

耗时的解决方案

所以我决定使用 angular-cli 创建一个新的 Angular2 项目,并使用 CLI 重建整个项目,同时从旧存储库复制代码并修复错误。

我遇到的错误是小问题(我认为它们是由于更新的 angular-cli 而改变 tslint.json 的结果)但没什么大不了的在项目中进行了更改,现在可以使用了。

错误信息中提到的源文件:

  • app.module.ts
  • tsconfig.json
  • angular-cli.json

没有一点改变,但 angular-cli 再次可用,ng serve 现在运行时不会遇到错误。

我认为这不是理想的解决方案(也不是降级到 1.0.0-beta.21)- 但这是我唯一能找到的。

关于angular-cli 25.5 模块构建失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41665950/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com