有没有人有一个使用SystemJS(而不是Webpack)与Angular2(TypeScript而不是Dart)和Cesium(npm)一起使用的工作示例?
我知道这篇关于cesiumjs网站的博客文章: https://cesiumjs.org/2016/01/26/Cesium-and-Webpack/
我喜欢作者说的话:“你不能简单地做一个require('cesium')
。”文章的问题在于它使用了Webpack的方式,而我没有那个可用。
无论如何,我想解决这个特定的错误(来自浏览器):
Error: (SystemJS) AMD模块http://localhost:3000/node_modules/cesium/Build/CesiumUnminified/Cesium.js未定义
这是我的代码:
在我的systemjs.config.js
文件中:
paths: {'npm:' : 'node_modules/'},
map: {
// our app is within the dist folder
app: 'dist',
// angular bundles
'@angular/core': 'npm:@angular/core/bundles/core.umd.js',
...
'require': 'npm:requirejs/require.js',
'cesium': 'npm:cesium/Build/CesiumUnminified/Cesium.js',
// Other packages
...
}
@Injectable()
示例:
let Cesium = require('cesium');
import { Injectable } from '@angular/core';
@Injectable()
export class CesiumClock {
private _start:any = Cesium.JulianDate.now();
private _stop:any = Cesium.JulianDate.addHours(this._start,12,new Cesium.JulianDate());
private _clock:any = new Cesium.Clock({
startTime: this._start,
stopTime: this._stop,
currentTime: this._start,
clockRange: Cesium.ClockRange.LOOP_STOP,
mutliplier: 1,
shouldAnimate: true
});
}
最后,客户端代码尝试使用我的“CesiumClock”,并在浏览器中转译后给我错误:
import { Component } from '@angular/core';
import { CesiumClock } from '../services/index';
@Component({
moduleId: module.id.replace("/dist", "/app"),
templateUrl: 'stuff.component.html',
styleUrls: [
'stuff.css',
'node_modules/cesium/Build/Cesium/Widgets/widgets.css'
]
})
export class StuffComponent {
constructor(private _cesiumClock:CesiumClock) {}
}
更新:
根据@artem
的答案,我成功从浏览器中删除了特定的“错误:(SystemJS)AMD”。但是现在,如果我想引用任何Cesium内容,例如new Cesium.Viewer(...)
,Cesium
对象就像一个空白的画布一样。我看到的错误信息是:
Cesium.Viewer不是一个构造函数