How do I solve ParseError: 'import' and 'export' may appear only with 'sourceType: module' when importing UpgradeAdapter?
How do I solve ParseError: 'import' and 'export' may appear only with 'sourceType: module' when importing UpgradeAdapter?
我正在尝试将现有的 anguar.js 应用程序升级到 angular 2,紧随 https://angular.io/docs/ts/latest/guide/upgrade.html。
该应用程序已经使用 Typescript 编写,我们正在使用 browserify 和 tsify 来编译和捆绑该应用程序。
在使用 npm 安装 angular 2 依赖项并尝试 bootstrap 混合应用程序后,browserify 给我以下错误:
/my-project/node_modules/@angular/upgrade/static.js:8
export { downgradeComponent } from './src/aot/downgrade_component';
^
ParseError: 'import' and 'export' may appear only with 'sourceType: module'
错误仅在添加以下代码后出现:
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
import {AppModule} from './app.module';
import {UpgradeModule} from '@angular/upgrade/static';
platformBrowserDynamic().bootstrapModule(AppModule).then(platformRef => {
const upgrade = platformRef.injector.get(UpgradeModule) as UpgradeModule;
upgrade.bootstrap(document.documentElement, ['sagaDesktopApp']);
});
这是我的 tsconfig.json
:
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"removeComments": false,
"noImplicitAny": false,
"suppressImplicitAnyIndexErrors": true
}
}
非常感谢任何帮助。
我已经重现了这个问题。这与 @angular/upgrade
中有一个 static.js
文件有关,当 Browserify 尝试解析 @angular/upgrade/static
时,它解析为:
node_modules/@angular/upgrade/static.js
然而,其意图是解决:
node_modules/@angular/upgrade/static/package.json
static
目录中的 package.json
包含一个 main
条目,供非 ES6 打包器(如 Browserify)使用。
Browserify 模仿 Node's module resolution mechanism,它应该在目录之前检查文件,因此要解决此问题,请在导入后附加一个斜杠:
import { UpgradeModule } from '@angular/upgrade/static/';
Browserify 然后将首先检查目录并将 package.json
解析为包。
如果您有兴趣,this Tsify issue.
中有关于 package.json
文件的 main
/module
内容的更多信息
我正在尝试将现有的 anguar.js 应用程序升级到 angular 2,紧随 https://angular.io/docs/ts/latest/guide/upgrade.html。
该应用程序已经使用 Typescript 编写,我们正在使用 browserify 和 tsify 来编译和捆绑该应用程序。
在使用 npm 安装 angular 2 依赖项并尝试 bootstrap 混合应用程序后,browserify 给我以下错误:
/my-project/node_modules/@angular/upgrade/static.js:8
export { downgradeComponent } from './src/aot/downgrade_component';
^
ParseError: 'import' and 'export' may appear only with 'sourceType: module'
错误仅在添加以下代码后出现:
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
import {AppModule} from './app.module';
import {UpgradeModule} from '@angular/upgrade/static';
platformBrowserDynamic().bootstrapModule(AppModule).then(platformRef => {
const upgrade = platformRef.injector.get(UpgradeModule) as UpgradeModule;
upgrade.bootstrap(document.documentElement, ['sagaDesktopApp']);
});
这是我的 tsconfig.json
:
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"removeComments": false,
"noImplicitAny": false,
"suppressImplicitAnyIndexErrors": true
}
}
非常感谢任何帮助。
我已经重现了这个问题。这与 @angular/upgrade
中有一个 static.js
文件有关,当 Browserify 尝试解析 @angular/upgrade/static
时,它解析为:
node_modules/@angular/upgrade/static.js
然而,其意图是解决:
node_modules/@angular/upgrade/static/package.json
static
目录中的 package.json
包含一个 main
条目,供非 ES6 打包器(如 Browserify)使用。
Browserify 模仿 Node's module resolution mechanism,它应该在目录之前检查文件,因此要解决此问题,请在导入后附加一个斜杠:
import { UpgradeModule } from '@angular/upgrade/static/';
Browserify 然后将首先检查目录并将 package.json
解析为包。
如果您有兴趣,this Tsify issue.
中有关于package.json
文件的 main
/module
内容的更多信息