javascript - 状态代码 OVER_QUERY_LIMIT Google map API

标签 javascript jquery google-maps-api-3

我有 20 个需要地理编码的地址。它们都是有效的。当我尝试对它们进行地理编码时,我得到了 OVER_QUERY_LIMIT。我还在 map 上放置了标记,每次我在 map 上得到不同数量的标记。我找到了这个OVER_QUERY_LIMIT in Google Maps ,但这对我没有帮助。另外,在地理编码标记数组的长度为 0 之后,我不知道为什么。此html代码:

 <div class="address-list">
                <ul>
                    <li data-address='ТРЦ Квадрат, бульвар Перова, 36, Киев, город Киев'>ТРЦ Квадрат, бульвар Перова 36</li>
                    <li data-address='Дніпровська набережна, 33'> ТЦ Аркадия, Днепровская Набережная 33 </li>
                    <li data-address='Срібнокільська, 3г, Київ'>  ТЦ ИнСилвьер, Срибнокольская 3г</li>
                    <li data-address="вулиця Лук'янівська, Київ"> ТЦ Квадрат, Белорусская 1</li>
                    <li data-address='проспект Генерала Ватутіна, 2, Київ, 02000'> ТЦ Скаймолл, проспект Генерала Ватутіна 2 </li>
                    <li data-address='вулиця Архітектора Вербицького 30а 30a, Київ, город Киев'> вулиця Архітектора Вербицького 30а</li>
                    <li data-address='Дніпровська набережна, 33, Київ, 02000'> Дніпровська набережна 33</li>
                    <li data-address='вулиця Михайла Гришка, 3а, Київ, 02000'> вулиця Михайла Гришка 3а</li>
                    <li data-address='вулиця Антоновича, 176, Київ, 03150'>ТРЦ Ocean Plaza, вулиця Антоновича 176</li>
                    <li data-address='вулиця Олександра Мишуги, 4, Київ'>ТЦ Пирамида, вулиця Олександра Мишуги 4</li>
                    <li data-address='вулиця Антоновича, 176, Київ, 03150'>ТРЦ Ocean Plaza, вулиця Антоновича 176</li>     
                    <li data-address='вулиця Олександра Архипенка, 6, Київ, 02000'>вулиця Мате Залки 6, Сильпо</li>
                    <li data-address='Бессарабська площа, Київ, 02000'>ТЦ Метроград, вулиця Красноармейская 13</li>
                    <li data-address='Спортивна площа, 1a, Київ, 01023'>ТЦ Гулливер, Спортивная 1а</li>
                    <li data-address='Спортивна площа, 1a, Київ, 01023'>ТЦ Гулливер, Спортивная 1а</li>
                    <li data-address='площа Льва Толстого, Київ, 01004'> ТЦ "Метроград", пл. Льва Толстого</li>
                    <li data-address='Майдан Незалежності, 1, Київ'>Пл. Майдан Независимости 1, ТЦ Глобус</li>
                </ul>
            </div>
            <div id="map">

            </div>

这是js代码:

var map;
var markers=[];
var addreses=[];
var buf=[];
var geocoder;
var delay = 100;
var index = 0;

function initMap() {
    map = new google.maps.Map(document.getElementById("map"),{
        center: { lat: 50.448998, lng: 30.522364},
        zoom: 11    
    });
    geocoder = new google.maps.Geocoder();
}

 $(function(){
     buf = $('.address-list ul li');
     for(var i = 0; i < buf.length; i++){
        var data = $(buf[i]).data('address');
        addreses[i] = data;
     }

     nextAddress();

    $('.address-list ul li').hover(
        function(e){
            for (var i = 0; i < buf.length; i++){
                var addr = $(this).data('address');
                if(addreses[i] == addr){
                    var pos = markers[i].getPosition();
                    map.setCenter(pos);
                    break;
                }
            }
        }
    );
});

function geocodeAddress(addr, mark, next){
    geocoder.geocode({'address': addr}, function(results, status){
        if(status === google.maps.GeocoderStatus.OK){ 
            mark = new google.maps.Marker({
                map: map,
                position: results[0].geometry.location
            });
            mark = results[0].geometry.location;
        }else{
            console.log('Error occured!' + status);
            if(status === google.maps.GeocoderStatus.OVER_QUERY_LIMIT){
                index--;
                delay++;
            }
        }
        console.log(markers.length);
        next();
    });
}

function nextAddress(){
    if(index < addreses.length){
        setTimeout(geocodeAddress(addreses[index], markers[index], nextAddress), delay);
        index++;
    }else{
        console.log("Markers done!!!" + markers.length);
    }
}

最佳答案

您实际上一次点击 20 个请求来进行地理编码。 地理编码器有配额和速率限制。您可以对 10 个位置进行地理编码,而不会达到查询限制(实际数量可能取决于服务器负载)。最好的解决方案是在收到 OVER_QUERY_LIMIT 错误时延迟,然后重试。像这样的事情

$(items).each(函数(i, item){

setTimeout(函数(){

geoLocate("address", function(myLatlng){
  ...value
});

}, 200);

}

关于javascript - 状态代码 OVER_QUERY_LIMIT Google map API,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38674964/

相关文章:

javascript - 在 Magento 的单页结帐期间是否触发了 JavaScript 事件?

javascript - 如何向 h2 标签添加文本并识别嵌入标签,例如 < i >

javascript - DOM/页面未更新,但 console.log 显示更新值

c# - 使用 C# 中的 Google map API 和 SSIS 包获取行驶距离

java - 最新的 Google Maps API V3(gwt-maps 3.10.0-alpha-7 除外)与 GWT 2.7.0 兼容吗?

php - 在 JavaScript 中插入 PHP 代码

javascript - 无法在循环中休眠

javascript - 为什么这个背景图像淡入插件会删除我的 div 内容?

javascript - 将多边形合并到 Google Maps API 3 中

javascript - 如何获取存储在javascript文件输入中的文件字典?