我正在使用angular2-google-maps
和最新版本的Angular2。我正试图将其中一些本地地图组件功能转换为它们自己的文件maps.service.ts
中的服务。例如:Angular2找不到名称空间'google'
map.component.ts
getGeoLocation(lat: number, lng: number) {
if (navigator.geolocation) {
let geocoder = new google.maps.Geocoder();
let latlng = new google.maps.LatLng(lat, lng);
let request = { latLng: latlng };
geocoder.geocode(request, (results, status) => {
if (status == google.maps.GeocoderStatus.OK) {
let result = results[0];
if (result != null) {
this.fillInputs(result.formatted_address);
} else {
alert("No address available!");
}
}
});
}
}
成类似:maps.service.ts
getGeoLocation(lat: number, lng: number): Observable<google.maps.GeocoderResult[]> {
let geocoder = new google.maps.Geocoder();
let latlng = new google.maps.LatLng(lat, lng);
let request = { latLng: latlng };
return new Observable((observer: Observer<google.maps.GeocoderResult[]>) => {
geocoder.geocode({ request }, (
(results: google.maps.GeocoderResult[], status: google.maps.GeocoderStatus) => {
if (status == google.maps.GeocoderStatus.OK) {
observer.next(results);
observer.complete();
} else {
console.log('Geocoding service failed due to: ' +status);
observer.error(status);
}
}
));
});
}
我得到的问题是,google
变量是不被认可的时候我尝试使用Observer<google.maps.GeocoderResult[]>
。我也有declare var google: any;
以外的服务类。
google
变量在我的map.componenet.ts
中有效,但在maps.service.ts
中未被识别。
你在哪里输入'google'? –
@GünterZöchbauer内的AppModule:'AgmCoreModule.forRoot({ apiKey: '--key--', 库:[ '地方'] })' – Milo
你需要一个打字稿进口所提供'google'。似乎你从某处复制了代码。你能发表一个链接吗? –