【问题标题】:cant make the gmaps.js search functions无法使 gmaps.js 搜索功能
【发布时间】:2015-12-18 08:48:05
【问题描述】:

我已经用 gmaps.js 制作了这个简单的应用程序,但我需要他们在这里展示的搜索功能:

http://hpneo.github.io/gmaps/examples/geocoding.html

我查看了源代码,但它没有工作。搜索按钮重新加载页面...

我的代码如下:

<script>
    $('#geocoding_form').submit(function(e){
        e.preventDefault();
        GMaps.geocode({
          address: $('#address').val().trim(),
          callback: function(results, status){
            if(status=='OK'){
              var latlng = results[0].geometry.location;
              map.setCenter(latlng.lat(), latlng.lng());
            }
          }
        });
      });
</script>


<form method="post" id="geocoding_form">
          <label for="address">Address:</label>
          <div class="input">
            <input type="text" id="address" name="address" />
            <input type="submit" class="btn" value="Search" />
          </div>
        </form>

<div id="map"></div>

其余部分是从 scripts.js 加载的,您可以在源代码中看到它。为什么会发生这种情况,我该如何解决?

网络应用程序位于此处,http://travelers.work/trein/

【问题讨论】:

标签: search gmaps.js


【解决方案1】:

你需要改变

map.setCenter(latlng.lat(), latlng.lng());

map.setCenter(latlng);

因为搜索会返回一个LatLng 对象作为结果,而这正是setCenter 的输入所需要的。

这是一个带有您的代码的 JS 演示:http://jsfiddle.net/DuRhR/3/

在 cmets 之后编辑:

或者,您可以传递给setCenter LatLngLiteral

map.setCenter({lat: latlng.lat(), lng: latlng.lng()});

【讨论】:

  • 你能在我制作的codepen上给我看这个吗? codepen.io/shiva112/pen/JGXoVJ
  • 您的 codepen 完美运行。在搜索字段中输入城市名称,例如“new york”(带或不带引号),您将看到地图重新以该位置为中心。
  • 其实,没有。这是每个文档:)
  • latlng 实际上都是函数,它不需要一个对象,而是 2 个不同的属性,因此 ,
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-08-30
  • 2019-04-03
  • 1970-01-01
  • 1970-01-01
  • 2017-03-21
相关资源
最近更新 更多