Pracuję z angular2-google-maps
i najnowszą wersją Angular2. Próbuję przekonwertować niektóre funkcje lokalnego komponentu mapy na usługi w ich własnym pliku maps.service.ts
. Na przykład:Angular2 Nie można znaleźć przestrzeni nazw "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!");
}
}
});
}
}
w coś podobnego: 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);
}
}
));
});
}
Kwestia Dostaję że google
jest zmienna nie jest rozpoznany, kiedy próbuję użyć Observer<google.maps.GeocoderResult[]>
. Mam również declare var google: any;
poza klasą usług.
Zmienna google
działa w moim map.componenet.ts
, ale nie zostaje rozpoznana w maps.service.ts
.
Gdzie importujesz "google"? –
@ GünterZöchbauer Within AppModule: 'AgmCoreModule.forRoot ({ apiKey: '--key--', bibliotek: [ 'miejsca'] })' – Milo
Musisz import maszynopis oraz który zapewnia 'google'. Wygląda na to, że skopiowałeś kod skądś. Czy możesz opublikować link? –