需要点击两次按钮才能提供javascript函数输出

时间:2016-03-21 13:17:18

标签: javascript jquery html asp.net google-maps

我试图使用反向地理定位和Google API获取状态代码,但在第一次点击时却没有获得字符串输出。在第二次单击时,似乎结果已经存在。如何在第一次点击按钮时显示它?被困在这一段时间了。

使用Javascript:

var distance="";
function RetrieveState() {
    geocoder2 = new google.maps.Geocoder();
    var latlng = new google.maps.LatLng(-41.495839, 147.172006);

    distance += " State is: "

    if (geocoder2) {geocoder2.geocode({ 'latLng': latlng }, function (results,     status)
    {
       if (status == google.maps.GeocoderStatus.OK)
       {
           var result = results[0];
           for (var i = 0, len = result.address_components.length; i < len; i++) {
               var ac = result.address_components[i];
               if (ac.types.indexOf("administrative_area_level_1") >= 0) 
                  distance +=  ac.short_name; 
           }
        }       
    }
}

document.getElementById("distance_road").innerHTML = distance;
} // end RetrieveState
通过ASP创建的

按钮:

<asp:Button ID="Button2" runat="server" Text="Button 2"  OnClientClick="RetrieveState()" />

输出: 第一次点击:状态是: 第二次点击:状态是:TAS状态是: 第三次点击:状态是:TAS状态是:TAS状态是:

2 个答案:

答案 0 :(得分:0)

这似乎是因为您没有在geocode回调函数中设置innerHTML - 这意味着您在返回地理编码结果之前设置innerHTML 。移动线:

document.getElementById("distance_road").innerHTML = distance;

到以下if语句的末尾:

if (status == google.maps.GeocoderStatus.OK)

答案 1 :(得分:0)

因为在第一次设置距离变量并且由于当代码第二次执行时它是全局的,所以它会移位,请尝试下面的代码。

var distance="";
    function RetrieveState() {
        geocoder2 = new google.maps.Geocoder();
        var latlng = new google.maps.LatLng(-41.495839, 147.172006);

        distance += " State is: "

        if (geocoder2) {geocoder2.geocode({ 'latLng': latlng }, function (results,     status)
        {
           if (status == google.maps.GeocoderStatus.OK)
           {
               var result = results[0];
               for (var i = 0, len = result.address_components.length; i < len; i++) {
                   var ac = result.address_components[i];
                   if (ac.types.indexOf("administrative_area_level_1") >= 0) 
                      distance +=  ac.short_name; 
               }
              document.getElementById("distance_road").innerHTML = distance;
           // end RetrieveState
            }       
        }
    }
  }