首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从@agm/ MouseEvent导入核心在Angular 9中不起作用

从@agm/ MouseEvent导入核心在Angular 9中不起作用
EN

Stack Overflow用户
提问于 2020-09-24 16:31:46
回答 2查看 3.6K关注 0票数 1

在我的Angular 9应用程序中,我正在使用agm google map,一切都在工作中查找,但是当我导入MouseEvent时,它显示了一个错误(src/app/place/place.component.ts:3:9 - error TS2305: Module '"../../../../../../Projects/Angular/mean2020/node_modules/@agm/core/agm-core"' has no exported member 'MouseEvent'.),我搜索了它,但没有找到任何适当的解决方案,任何人的帮助,感谢事先

这是可能的ts文件

代码语言:javascript
复制
import { Component, OnInit, ViewChild, ElementRef, NgZone } from '@angular/core';
import { MapsAPILoader } from '@agm/core';
import { MouseEvent } from '@agm/core';

   markerDragEnd($event: MouseEvent) {
        console.log($event);
        this.latitude = $event.coords.lat;
        this.longitude = $event.coords.lng;
        this.getAddress(this.latitude, this.longitude);
    }
EN

回答 2

Stack Overflow用户

发布于 2020-09-24 16:58:10

从新的3.0.0测试版开始,MouseEvent不是来自@agm/core,而是来自谷歌地图脚本。

尝试安装types包

代码语言:javascript
复制
npm install --save @types/googlemaps

并像这样使用它:

代码语言:javascript
复制
import {
  Component,
  OnInit,
  ViewChild,
  ElementRef,
  NgZone
} from '@angular/core';
import {
  MapsAPILoader
} from '@agm/core';

markerDragEnd($event: google.maps.MouseEvent) {
  console.log($event);
  this.latitude = $event.coords.lat;
  this.longitude = $event.coords.lng;
  this.getAddress(this.latitude, this.longitude);
}

您的tsconfig还应更新为包含以下内容:

代码语言:javascript
复制
"types": [
      "googlemaps"
]

这是由于来自agm的最新版本(refer to their changelog)造成的。

票数 1
EN

Stack Overflow用户

发布于 2020-10-14 13:26:32

如前所述,自从新的3.0.0-beta版本以来,MouseEvent不是来自@agm/core,而是来自谷歌地图脚本。

并且您必须添加到tsconfig中

代码语言:javascript
复制
"types": [
      "googlemaps"
]

但是,此接口没有名为coord的属性,而是具有latLng属性,该属性具有latlng两个函数,因此不使用

代码语言:javascript
复制
this.latitude = $event.coords.lat;
this.longitude = $event.coords.lng;

你的代码应该是:

代码语言:javascript
复制
markerDragEnd($event: google.maps.MouseEvent) {
  console.log($event);
  this.latitude = $event.latLng.lat();
  this.longitude = $event.latLng.lng();
  this.getAddress(this.latitude, this.longitude);
}

我试过了,因为我有同样的问题,希望它是有用的。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64042499

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档