- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在 Angular 5 应用程序中使用 Angular Google map ( https://angular-maps.com/ ),还使用 socket.io 从服务器轮询纬度和经度。我能够将数据推送到组件中的数组,但 agm-map 没有得到更新
组件.ts
import { Component, OnInit } from '@angular/core';
import { SocketService } from '../../app/services/socket.service';
@Component({
selector: 'app-maps',
templateUrl: './maps.component.html',
styleUrls: ['./maps.component.scss']
})
export class MapsComponent implements OnInit {
public title: string = 'AGM project';
public lat: number = 12.954517;
public lng: number = 77.3507335;
public msg : string;
public mcar =
"https://maps.google.com/mapfiles/kml/shapes/parking_lot_maps.png";
public agmMarkers: agmmarker[] = [
{
lat: 12.954517,
lng: 77.3507335,
icn: this.mcar
}
];
constructor(private socketService : SocketService) { }
ngOnInit() {
this.socketService
.getMessage()
.subscribe((msg: any) => {
console.log("msg: "+JSON.stringify(msg));
this.updateMarkers(msg);
});
}
public updateMarkers(msg){
this.agmMarkers = [];
for (let entry of msg.stats) {
console.log("entry.latlng.lat: "+entry.latlng.lat);
console.log("entry.latlng.lng: "+entry.latlng.lng);
this.agmMarkers.push({
lat: entry.latlng.lat,
lng: entry.latlng.lng,
icn: this.mcar
});
}
}
}
interface agmmarker {
lat?: number;
lng?: number;
icn?: string;
}
组件.html
<agm-map [latitude]="lat" [longitude]="lng">
<agm-marker *ngFor="let i of agmMarkers"
[latitude]="i.lat" [longitude]="i.lng" [iconUrl]="i.icn">
</agm-marker>
</agm-map>
最佳答案
我的错。来自服务的响应是字符串格式。
this.agmMarkers.push({
lat: +entry.latlng.lat,
lng: +entry.latlng.lng,
icn: this.mcar
});
类型转换纬度和经度解决了这个问题。
关于angular - agm-map 动态显示/更新标记不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50868716/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!