如果我对数据进行硬编码,那么所有标记都会很好地显示出来。如果我评论这一行this.markers.push(newMarker) ; 并用下一个替换它,我得到一个ERROR TypeError: Cannot read property 'push' of undefine
如果我使用this.markers = [newMarkers]只有一个最后一个 json 元素显示为标记。
如何同时显示所有标记,这是 async 的问题吗?
ngOnInit() {
this._mapService.getMarkers().subscribe(data => {
data.map(a => {
const lat = a.lat;
const lng = a.lng;
const name = a.name;
const newMarker = marker(
[lat, lng], {
icon: icon({
iconSize: [25, 25],
iconAnchor: [13, 41],
iconUrl: 'assets/yellow.png',
})
}
);
newMarker.bindPopup('<p>' + name + '</p>', {autoPan: true});
// this.markers.push(newMarker);
this.markers = [newMarker];
});
服务
@Injectable({
providedIn: 'root'
})
export class MapserviceService {
private _markers = '../../assets/markers/markers.json';
constructor(private http: HttpClient) {}
getMarkers(): Observable<any> {
return this.http.get<any>(this._markers);
}
JSON数据
[{
"name": "Canada",
"lat": 56.130366,
"lng": -106.346771
},
...
{
"name": "Anguilla",
"lat": 18.220554,
"lng": -63.068615
}
]
有效的硬编码数据
function createIcon2() {
return icon({
iconSize: [25, 25],
iconAnchor: [13, 41],
iconUrl: 'assets/yellow.png',
});
}
this.markers =
[
marker([35, -76], { icon: createIcon2() }),
marker([36, -81], { icon: createIcon2() }),
marker([37, -88], { icon: createIcon2() }),
marker([38, -99], { icon: createIcon2() }),
marker([39, -111], { icon: createIcon2() })
];
console.log('working', this.markers);