首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用google-places时无法读取未定义的属性“自动完成”

使用google-places时无法读取未定义的属性“自动完成”
EN

Stack Overflow用户
提问于 2019-06-27 06:34:43
回答 2查看 2.5K关注 0票数 0

我想在文本框中得到输入地址的LatLng。我正在使用谷歌地图api作为它。通过只编写新的google.maps.places.Autocomplete({}),我得到的无法读取未定义的的属性'places‘--这个错误。

下面是我的代码:

代码语言:javascript
复制
@ViewChild('addressText') addressText: any;

ngAfterViewInit() {
   this.getPlaceAutocomplete();
}

getPlaceAutocomplete() {
    const autoComplete = new google.maps.places.Autocomplete(this.addressText.nativeElement, {
      types: this.addressText.nativeElement.value
    })
    // google.maps.event.addListener(autoComplete, 'place_changed', () => {
    //   const place = autoComplete.getPlace();

    //   console.log('places... ', place);
    // })
  }

html文件:

代码语言:javascript
复制
<input matInput placeholder="Locations" class="input" formControlName="text" #addressText>

请帮帮我。

EN

回答 2

Stack Overflow用户

发布于 2022-03-11 14:13:20

我也面临着同样的问题,我忘记了在关键的&libraries=places src="KEY&libraries=places“之后添加KEY&libraries=places

票数 1
EN

Stack Overflow用户

发布于 2019-06-27 07:25:48

错误是因为没有创建“自动完成”对象。

  • 您需要为“输入”标记定义一个id。
  • 只是给你一个基本的例子。

HTML:

代码语言:javascript
复制
<input matInput placeholder="Locations" class="input" formControlName="text" id="addressText">

JS:

代码语言:javascript
复制
autocomplete = new google.maps.places.Autocomplete(
  document.getElementById('addressText'), {types: ['geocode']});

有关详细信息,请浏览docs google自动完成

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

https://stackoverflow.com/questions/56785215

复制
相关文章

相似问题

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