0

我正在使用 Google maps apiv3 开发一个网站。我在更新面板中有一个按钮,通过它我使用 button_click 后面的代码和 javascript 函数执行一些逻辑。

由于该按钮位于更新面板中,因此我无法在 firebug 的监视窗口中看到任何内容,并且我在 javascript 函数中的断点也不起作用。如果没有更新面板,我可以在手表中看到执行流程,一切正常,但我在地图上重新加载。

aspx 中的代码:

    <asp:ScriptManager ID="ScriptManager1" runat="server"> </asp:ScriptManager>
    <asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional">
        <ContentTemplate>
            <asp:Button ID="Button1" runat="server" style="z-index: 1; left: 573px; top: 146px; position: absolute" Text="Show route" onclick="Button1_Click1"/>
        </ContentTemplate>
        <Triggers>
            <asp:AsyncPostBackTrigger ControlID="Button1" EventName="Click"/>
        </Triggers>
    </asp:UpdatePanel>

按钮_点击1:

protected void Button1_Click1(object sender, EventArgs e)
{
    using (con = new MySqlConnection("server=localhost; uid=root;password=as64ws;database=Gmaps"))
    da = new MySqlDataAdapter("select * from routes where uid='a1'", con);
    da.Fill(ds, "mroute");
    foreach (DataRow r in ds.Tables[0].Rows)
    {
        uroute.Add(r["latlng"].ToString());
    }
    croute = new string[uroute.Count];
    croute = uroute.ToArray();
    hdncroute.Value = string.Join("&", croute);
    ScriptManager.RegisterClientScriptBlock(this, typeof(Button), "routes", "droute()", true);
}

Javascript:

function droute()
{
    var route=[];
    var temp;
    temp = document.getElementById('<%= hdncroute.ClientID %>').value;
    route= temp.split('&');
    //Loop to add locations and draw line
    var path= polyline.getPath();
    for(var i=0;i<route.length;i++)
        {
            var input= route[i];
            var ltln = input.split(",",2);
            var lat=parseFloat(ltln[0]);
            var lng=parseFloat(ltln[1]);
            var pos= new google.maps.LatLng(lat,lng);
            var marker= new google.maps.Marker({position:pos,map:map});
            path.push(route[i]);
            google.maps.event.addListener(marker,'click',showiwindow);
        }
    function showiwindow(event)
    {
    iwindow.setContent("<b>Coordinates are:</b><br/>Latitude:"+event.latLng.lat()+"<br/>Longitude:"+event.latLng.lng());
    iwindow.open(map,this);
    } 
}

我无法获得要在地图上显示的值。我应该将按钮放在更新面板中还是将地图放在更新面板中?我哪里错了?

4

2 回答 2

1

我会废弃你的大部分逻辑。

我会让按钮单击在您的代码隐藏中执行一个 jquery ajax 发布到 Web 服务,这会将一个数组返回到您的 ajax 发布,然后在您的 ajax 发布的成功部分中,我会触发您的 javascript 例程。

http://dotnetguts.blogspot.com/2012/01/jquery-ajax-examples-by-calling-aspnet.html

我上面描述的是我几乎所有的谷歌地图调用.......在我读过的关于这个主题的近 100 页中,我还没有看到更合适的方法。如果您需要了解有关如何以这种方式进行操作的更多信息,请告诉我。

这是另一个很好的页面,描述了如何做 jquery ajax 帖子。:

从 Jquery 调用方法背后的代码

于 2012-09-14T00:38:37.827 回答
0

设置 UpdateMode="Conditional" 并将 Button 设置为 AsynPostBacktrigger。可能这会解决问题。

于 2012-09-11T23:32:03.677 回答